91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

利用css解決不同瀏覽器下文本兼容的問題

發布時間:2020-04-07 09:49:50 來源:億速云 閱讀:194 作者:小新 欄目:web開發

這篇文章主要為大家詳細介紹了利用css解決不同瀏覽器下文本兼容的問題,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下。

利用css解決不同瀏覽器下文本兼容的問題

目標:

css實現不同瀏覽器下兼容文本兩端對齊。

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

利用css解決不同瀏覽器下文本兼容的問題

解決過程:

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

css

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

html

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

利用css解決不同瀏覽器下文本兼容的問題

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

利用css解決不同瀏覽器下文本兼容的問題

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

css

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

利用css解決不同瀏覽器下文本兼容的問題

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

2、接著思考,既然上述實現存在兼容性問題,那么能不能為 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>

利用css解決不同瀏覽器下文本兼容的問題

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

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

html

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

css

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

利用css解決不同瀏覽器下文本兼容的問題

想想還有一些小激動呢,而且完美兼容 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" });

利用css解決不同瀏覽器下文本兼容的問題

好了,這種方案應該能支持主流的瀏覽器了,但缺點是由于通過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" })
}

完成!

利用css解決不同瀏覽器下文本兼容的問題就分享到這里了,當然并不止以上和大家分析的辦法,不過小編可以保證其準確性是絕對沒問題的。希望以上內容可以對大家有一定的參考價值,可以學以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

css
AI

丰城市| 云梦县| 综艺| 盘锦市| 屏东市| 改则县| 沅陵县| 东宁县| 云龙县| 盘山县| 边坝县| 沁水县| 乐陵市| 黄龙县| 繁峙县| 嘉荫县| 枣庄市| 洛宁县| 东莞市| 元谋县| 长宁县| 象州县| 临漳县| 鄂托克前旗| 耒阳市| 含山县| 清徐县| 张掖市| 贵阳市| 罗源县| 芮城县| 潮州市| 四平市| 沐川县| 额济纳旗| 安图县| 南京市| 新竹县| 绍兴县| 简阳市| 东宁县|