中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊

小編給大家分享一下css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序定制開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了肇慶免費(fèi)建站歡迎大家使用!

在 form 表單的前端布局中,我們經(jīng)常需要將文本框的提示文本兩端對齊,例如:

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊

比較粗暴的做法是在需要隔離邊距的文本中加標(biāo)簽,然后分別控制每個文字的邊距,這種方法比直接加空格或者占位符更精準(zhǔn),我之前也都是這么做的。但是寫的多了之后開始思考能不能抽象出來用于更多的場景?讓代碼更好看一些?維護(hù)成本更低一些?

1、首先想到是能不能直接靠 css 解決問題

css

.test-justify {
    text-align: justify;
}

html

 <div class="test-justify">
        測試文本
 </div>

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊

好吧,text-align:justify 完全無效,不甘心,于是用一段文本測試了下,效果如下:

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊

原來這個屬性是針對段落文本兩端對齊的,接著試一下 text-align-last: justify 這個屬性

css

.test-justify {
    text-align: justify;
}

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊

效果是達(dá)到了,但缺點(diǎn)是完全不兼容 ie 和 safari 瀏覽器。

2、接著思考,既然上述實(shí)現(xiàn)存在兼容性問題,那么能不能為 2 個,3 個,4 個等這樣長度的文本單獨(dú)寫 css 類解決,因?yàn)楸韱蔚奈谋究蛱崾疚淖忠膊粫芏唷?/strong>

css

div {
    width: 100px;
}
.w2 {
    letter-spacing: 2em;
}
.w3 {
    letter-spacing: 0.5em;
}

html

<div class="w2">測試</div>
<div class="w3">測試了</div>
<div>測試來了</div>

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊
 

這種方案看起來能夠解決問題,應(yīng)對大部分場景應(yīng)該沒問題了,但遺憾的是并不是真正的兩端對齊,特殊顯示的情況下還是無法滿足需求,我們先放著,繼續(xù)往下嘗試。

2、以上是純 css 實(shí)現(xiàn)方式,接下來我們看看 css 和 dom 結(jié)合能不能做出統(tǒng)一形式的解決方案。

html

<div class="test-justify">
    測 試 文 本
    <span></span>
</div>

css

.test-justify {
    text-align: justify;
}
span {
    display:inline-block;
    padding-left:100%;
}

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊
 

想想還有一些小激動呢,而且完美兼容 ie 和 safari,這種方案其實(shí)就是第一種段落對齊方案的擴(kuò)展,用空格強(qiáng)制分詞,然后用 span 偽造最后一行(test-justify 不會對最后一行進(jìn)行對齊)。

為了增加擴(kuò)展性,我們還得對這種方案進(jìn)行優(yōu)化,因?yàn)榇蠖鄶?shù)情況下文本是后端加載的。

例如 .net core razor 視圖加載 model displayname 的寫法
<label asp-for="Email"></label>

只要加一小段js然后就應(yīng)該能兼容所有場景了。
css

div {
    width: 300px;
    border: 1px solid #000;
}
.test-justify {
    text-align: justify;
}
span {
    display:inline-block;
    padding-left:100%;
}

html

<div class="test-justify">
    測試文本
</div>

js

var $this = $(".test-justify")
, justifyText = $this.text().trim()
, afterText = "";
for (var i = 0; i < justifyText.length; i++) {
    afterText += justifyText[i] + " ";
}
afterText = afterText.trim() + "<span></span>";
$this.html(afterText).css({ "height": $this.height() / 2 + "px" });

css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊

好了,這種方案應(yīng)該能支持主流的瀏覽器了,但缺點(diǎn)是由于通過js再調(diào)整的,所以刷新的時候仔細(xì)看會看到文本兩端對齊的過程(閃一下),體驗(yàn)并不是很好,那就做一下兼容吧。
只有 IE 和 Safari 不支持 text-align-last: justify 所以只考慮這兩種瀏覽器的情況下調(diào)用最后一種方案

function myBrowser() {
    var userAgent = navigator.userAgent;

    //判斷瀏覽器版本  
    var isOpera = userAgent.indexOf("Opera") > -1; 
    var isIE = userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1 && !isOpera; 
    var isEdge = userAgent.toLowerCase().indexOf("edge") > -1 && !isIE; 
    var isIE11 = (userAgent.toLowerCase().indexOf("trident") > -1 && userAgent.indexOf("rv") > -1);

    if (/[Ff]irefox(\/\d+\.\d+)/.test(userAgent)) {
        return "Firefox";
    } else if (isIE) {
        return "IE";
    } else if (isEdge) {
        return "IE";
    } else if (isIE11) {
        return "IE";
    } else if (/[Cc]hrome\/\d+/.test(userAgent)) {
        return "Chrome";
    } else if (/[Vv]ersion\/\d+\.\d+\.\d+(\.\d)* *[Ss]afari/.test(userAgent)) {
        return "Safari"
    } else {
        return "unknown"
    }
}

var browser = myBrowser();
if (browser == "IE" || browser == "Safari") {
    var $this = $(".test-justify")
        , justifyText = $this.text().trim()
        , afterText = "";
    for (var i = 0; i < justifyText.length; i++) {
        afterText += justifyText[i] + " ";
    }
    afterText = afterText.trim() + "<span></span>";
    $this.html(afterText).css({ "height": $this.height() / 2 + "px" })
}

以上是“css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文名稱:css如何實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對齊
本文鏈接:http://www.rwnh.cn/article34/gpogpe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、移動網(wǎng)站建設(shè)、品牌網(wǎng)站制作Google、自適應(yīng)網(wǎng)站、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

洛川县| 丹棱县| 延津县| 彰武县| 泌阳县| 昌黎县| 玉龙| 连州市| 高密市| 含山县| 银川市| 漾濞| 班戈县| 垫江县| 万盛区| 富锦市| 射阳县| 孟津县| 长泰县| 义马市| 楚雄市| 荥经县| 禄丰县| 临洮县| 贡觉县| 泸溪县| 临汾市| 黄浦区| 疏附县| 弋阳县| 衡南县| 乌鲁木齐县| 长垣县| 桓仁| 平舆县| 澄城县| 河北省| 台东县| 锡林郭勒盟| 阿瓦提县| 尼玛县|