這篇文章主要為大家詳細(xì)介紹了利用css解決不同瀏覽器下文本兼容的問題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
我們提供的服務(wù)有:成都網(wǎng)站制作、做網(wǎng)站、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、金城江ssl等。為超過千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的金城江網(wǎng)站制作公司目標(biāo):
css實(shí)現(xiàn)不同瀏覽器下兼容文本兩端對(duì)齊。
在 form 表單的前端布局中,我們經(jīng)常需要將文本框的提示文本兩端對(duì)齊,例如:
解決過程:
1、首先想到是能不能直接靠 css 解決問題
css
.test-justify { text-align: justify; }
html
測(cè)試文本
好吧,text-align:justify 完全無效,不甘心,于是用一段文本測(cè)試了下,效果如下:
原來這個(gè)屬性是針對(duì)段落文本兩端對(duì)齊的,接著試一下 text-align-last: justify 這個(gè)屬性
css
.test-justify { text-align: justify; }
效果是達(dá)到了,但缺點(diǎn)是完全不兼容 ie 和 safari 瀏覽器。
2、接著思考,既然上述實(shí)現(xiàn)存在兼容性問題,那么能不能為 2 個(gè),3 個(gè),4 個(gè)等這樣長度的文本單獨(dú)寫 css 類解決,因?yàn)楸韱蔚奈谋究蛱崾疚淖忠膊粫?huì)很多。
css
div { width: 100px; } .w2 { letter-spacing: 2em; } .w3 { letter-spacing: 0.5em; }
html
測(cè)試測(cè)試了測(cè)試來了
這種方案看起來能夠解決問題,應(yīng)對(duì)大部分場(chǎng)景應(yīng)該沒問題了,但遺憾的是并不是真正的兩端對(duì)齊,特殊顯示的情況下還是無法滿足需求,我們先放著,繼續(xù)往下嘗試。
2、以上是純 css 實(shí)現(xiàn)方式,接下來我們看看 css 和 dom 結(jié)合能不能做出統(tǒng)一形式的解決方案。
html
測(cè) 試 文 本
css
.test-justify { text-align: justify; } span { display:inline-block; padding-left:100%; }
想想還有一些小激動(dòng)呢,而且完美兼容 ie 和 safari,這種方案其實(shí)就是第一種段落對(duì)齊方案的擴(kuò)展,用空格強(qiáng)制分詞,然后用 span 偽造最后一行(test-justify 不會(huì)對(duì)最后一行進(jìn)行對(duì)齊)。
為了增加擴(kuò)展性,我們還得對(duì)這種方案進(jìn)行優(yōu)化,因?yàn)榇蠖鄶?shù)情況下文本是后端加載的。
例如: .net core razor 視圖加載 model displayname 的寫法
只要加一小段js然后就應(yīng)該能兼容所有場(chǎng)景了。
css
div { width: 300px; border: 1px solid #000; } .test-justify { text-align: justify; } span { display:inline-block; padding-left:100%; }
html
測(cè)試文本
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)該能支持主流的瀏覽器了,但缺點(diǎn)是由于通過js再調(diào)整的,所以刷新的時(shí)候仔細(xì)看會(huì)看到文本兩端對(duì)齊的過程(閃一下),體驗(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() + ""; $this.html(afterText).css({ "height": $this.height() / 2 + "px" }) }
完成!
利用css解決不同瀏覽器下文本兼容的問題就分享到這里了,當(dāng)然并不止以上和大家分析的辦法,不過小編可以保證其準(zhǔn)確性是絕對(duì)沒問題的。希望以上內(nèi)容可以對(duì)大家有一定的參考價(jià)值,可以學(xué)以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。