不一樣瀏覽器下兼容文本兩端對齊

在 form 表單的前端佈局中,咱們常常須要將文本框的提示文本兩端對齊,例如:javascript

比較粗暴的作法是在須要隔離邊距的文本中加標籤,而後分別控制每一個文字的邊距,這種方法比直接加空格或者佔位符更精準,我以前也都是這麼作的。可是寫的多了以後開始思考能不能抽象出來用於更多的場景?讓代碼更好看一些?維護成本更低一些?css


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

css前端

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

htmljava

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

好吧,text-align:justify 徹底無效,不甘心,因而用一段文本測試了下,效果以下:後端

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

cssdom

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

效果是達到了,但缺點是徹底不兼容 ie 和 safari 瀏覽器。ide

二、接着思考,既然上述實現存在兼容性問題,那麼能不能爲 2 個,3 個,4 個等這樣長度的文本單獨寫 css 類解決,由於表單的文本框提示文字也不會不少。佈局

css

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

html

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


此方案參考自blog.csdn.net/muyutingfeng2008/article/details/48263073

這種方案看起來可以解決問題,應對大部分場景應該沒問題了,但遺憾的是並非真正的兩端對齊,特殊顯示的狀況下仍是沒法知足需求,咱們先放着,繼續往下嘗試。

二、以上是純 css 實現方式,接下來咱們看看 css 和 dom 結合能不能作出統一形式的解決方案。

html

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

css

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


想一想還有一些小激動呢,並且完美兼容 ie 和 safari,這種方案其實就是第一種段落對齊方案的擴展,用空格強制分詞,而後用 span 僞造最後一行(test-justify 不會對最後一行進行對齊)。

爲了增長擴展性,咱們還得對這種方案進行優化,由於大多數狀況下文本是後端加載的。

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

只要加一小段js而後就應該能兼容全部場景了。
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" });

好了,這種方案應該能支持主流的瀏覽器了,但缺點是因爲經過js再調整的,因此刷新的時候仔細看會看到文本兩端對齊的過程(閃一下),體驗並非很好,那就作一下兼容吧。
只有 IE 和 Safari 不支持 text-align-last: justify 因此只考慮這兩種瀏覽器的狀況下調用最後一種方案

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" })
}

哈哈哈,完美!

第一次寫博客,點個讚唄,要是有更好的解決方案,歡迎留言~~~


補充:由於空格增長了字間距,爲了達到最佳呈現效果能夠隨意增長一個極限的單詞邊距 word-spacing: -10px


個人公衆號《有刻》,咱們共同成長!

相關文章
相關標籤/搜索