小編給大家分享一下css如何實現(xiàn)不同瀏覽器下兼容文本兩端對齊,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
目前累計服務(wù)客戶成百上千,積累了豐富的產(chǎn)品開發(fā)及服務(wù)經(jīng)驗。以網(wǎng)站設(shè)計水平和技術(shù)實力,樹立企業(yè)形象,為客戶提供網(wǎng)站設(shè)計、成都網(wǎng)站制作、網(wǎng)站策劃、網(wǎng)頁設(shè)計、網(wǎng)絡(luò)營銷、VI設(shè)計、網(wǎng)站改版、漏洞修補(bǔ)等服務(wù)。創(chuàng)新互聯(lián)公司始終以務(wù)實、誠信為根本,不斷創(chuàng)新和提高建站品質(zhì),通過對領(lǐng)先技術(shù)的掌握、對創(chuàng)意設(shè)計的研究、對客戶形象的視覺傳遞、對應(yīng)用系統(tǒng)的結(jié)合,為客戶提供更好的一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進(jìn)步。在 form 表單的前端布局中,我們經(jīng)常需要將文本框的提示文本兩端對齊,例如:
比較粗暴的做法是在需要隔離邊距的文本中加標(biāo)簽,然后分別控制每個文字的邊距,這種方法比直接加空格或者占位符更精準(zhǔn),我之前也都是這么做的。但是寫的多了之后開始思考能不能抽象出來用于更多的場景?讓代碼更好看一些?維護(hù)成本更低一些?
1、首先想到是能不能直接靠 css 解決問題
css
.test-justify { text-align: justify; }
html
測試文本
好吧,text-align:justify
完全無效,不甘心,于是用一段文本測試了下,效果如下:
原來這個屬性是針對段落文本兩端對齊的,接著試一下text-align-last: justify
這個屬性
css
.test-justify { text-align: justify; }
效果是達(dá)到了,但缺點是完全不兼容 ie 和 safari 瀏覽器。
2、接著思考,既然上述實現(xiàn)存在兼容性問題,那么能不能為 2 個,3 個,4 個等這樣長度的文本單獨寫 css 類解決,因為表單的文本框提示文字也不會很多。
css
div { width: 100px; } .w2 { letter-spacing: 2em; } .w3 { letter-spacing: 0.5em; }
html
測試測試了測試來了
這種方案看起來能夠解決問題,應(yīng)對大部分場景應(yīng)該沒問題了,但遺憾的是并不是真正的兩端對齊,特殊顯示的情況下還是無法滿足需求,我們先放著,繼續(xù)往下嘗試。
2、以上是純 css 實現(xiàn)方式,接下來我們看看 css 和 dom 結(jié)合能不能做出統(tǒng)一形式的解決方案。
html
測 試 文 本
css
.test-justify { text-align: justify; } span { display:inline-block; padding-left:100%; }
想想還有一些小激動呢,而且完美兼容 ie 和 safari,這種方案其實就是第一種段落對齊方案的擴(kuò)展,用空格強(qiáng)制分詞,然后用 span 偽造最后一行(test-justify 不會對最后一行進(jìn)行對齊)。
為了增加擴(kuò)展性,我們還得對這種方案進(jìn)行優(yōu)化,因為大多數(shù)情況下文本是后端加載的。
例如 .net core razor 視圖加載 model displayname 的寫法
只要加一小段js然后就應(yīng)該能兼容所有場景了。
css
div { width: 300px; border: 1px solid #000; } .test-justify { text-align: justify; } span { display:inline-block; padding-left:100%; }
html
測試文本
js
var $this = $(".test-justify") , justifyText = $this.text().trim() , afterText = ""; for (var i = 0; i < justifyText.length; i++) { afterText += justifyText[i] + " "; } afterText = afterText.trim() + ""; $this.html(afterText).css({ "height": $this.height() / 2 + "px" });
好了,這種方案應(yīng)該能支持主流的瀏覽器了,但缺點是由于通過js再調(diào)整的,所以刷新的時候仔細(xì)看會看到文本兩端對齊的過程(閃一下),體驗并不是很好,那就做一下兼容吧。
只有 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() + ""; $this.html(afterText).css({ "height": $this.height() / 2 + "px" }) }
以上是“css如何實現(xiàn)不同瀏覽器下兼容文本兩端對齊”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!