巧用CSS屬性值正則匹配選擇器(小技巧)
屬性值正則匹配選擇器包括下面3種:
- [attr^="val"]
- [attr$="val"]
- [attr*="val"]
這3種屬性選擇器是字符匹配,而非單詞匹配。其中,尖角符號^、美元符號$以及星號*都是正則表達式中的特殊標識符,分別表示前匹配、后匹配和任意匹配。
利用這些選擇器,純CSS就可以做出很炫酷的功能。
<!-- more -->
顯示超鏈接的小圖標和文件類型圖表
利用[attr^="val"]前匹配選擇器可以判斷<a>元素的鏈接地址類型,以用來顯示對應(yīng)的小圖標。顯示超鏈接的小圖標的樣式如下:
[href] {padding-left: 18px;}
/* 鏈接地址 */
[href^="https"],
[href^="//"] {
background: url("./images/link.png") no-repeat left;
}
/* 網(wǎng)頁內(nèi)錨鏈 */
[href^="#"] {
background: url("./images/anchor.png") no-repeat left;
}
/* 手機和郵箱 */
[href^="tel:"] {
background: url("./images/tel.png") no-repeat left;
}
[href^="mailto:"] {
background: url("./images/e-mail.png") no-repeat left;
}
效果

而利用[attr$="val"]后匹配選擇器則可以實現(xiàn)顯示文件類型小圖標。CSS如下:
/* 指向PDF文件 */
[href$=".pdf"] {
background: url("./images/pdf.png") no-repeat left;
}
/* 下載zip壓縮文件 */
[href$=".zip"] {
background: url("./images/zip.png") no-repeat left;
}
/* 圖片鏈接 */
[href$=".png"],
[href$=".gif"],
[href$=".jpg"],
[href$=".jpeg"],
[href$=".webp"] {
background: url("./images/image.png") no-repeat left;
}
效果如下

CSS屬性選擇器搜索過濾技術(shù)
我們可以借助屬性選擇器來輔助我們實現(xiàn)搜索過濾效果,如通訊錄、城市列表,這樣做性能高,代碼少。
HTML結(jié)構(gòu)如下:
<input type="search" id="input" placeholder="輸入城市名稱或拼音" />
<ul>
<li data-search="重慶市 chongqing">重慶市</li>
<li data-search="哈爾濱市 haerbin">哈爾濱市</li>
<li data-search="長春市 changchun">長春市</li>
<li data-search="長沙市 changsha">長沙市</li>
<li data-search="上海市 shanghai">上海市</li>
<li data-search="杭州市 hangzhou">杭州市</li>
</ul>
此時,當(dāng)我們在輸入框種輸入內(nèi)容的時候,只要根據(jù)輸入內(nèi)容動態(tài)創(chuàng)建一段CSS代碼就可以實現(xiàn)搜索匹配效果了,無需自己寫代碼進行匹配驗證。
var eleStyle = document.createElement('style');
document.head.appendChild(eleStyle);
// 文本輸入框
input.addEventListener('input', function() {
var value = this.value.trim();
eleStyle.innerHTML = value ? '[data-search]:not([data-search*="' + value +'"]) { display: none; } ' : '';
});
到此這篇關(guān)于巧用CSS屬性值正則匹配選擇器(小技巧)的文章就介紹到這了,更多相關(guān)CSS屬性值正則匹配內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!
相關(guān)文章
這篇文章主要介紹了css3的focus-within選擇器的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)2020-05-11
這篇文章主要介紹了CSS選擇器中的正則表達式使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)2020-03-11- 這篇文章主要介紹了css選擇器四大類:基本、組合、屬性、偽類的相關(guān)知識,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-14
- 這篇文章主要介紹了css復(fù)雜選擇器及css字體樣式、顏色屬性,復(fù)雜選擇有三種,每種方法通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧2020-01-19

詳解如何使用CSS3中的結(jié)構(gòu)偽類選擇器和偽元素選擇器
這篇文章主要介紹了詳解如何使用CSS3中的結(jié)構(gòu)偽類選擇器和偽元素選擇器,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面2020-01-06- 這篇文章主要介紹了CSS3 新增選擇器的實例,需要的朋友可以參考下2019-11-13
如果說 css 作為前端開發(fā)的基本功, 那么 "選擇器" 就是基礎(chǔ)中的基礎(chǔ),本文介紹了css3 偽類選擇器快速復(fù)習(xí),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工2019-09-10- 這篇文章主要介紹了CSS 樣式的使用方式、選擇器 的相關(guān)資料,需要的朋友可以參考下2019-08-12
CSS 選擇器在實踐中是非常常用的,無論是在寫樣式上或是在 JS 中選擇 DOM 元素都需要用到。在 CSS Selectors Level 4 中,工作組繼續(xù)為選擇器標準添加了更豐富的選擇器。需2018-12-24
這篇文章主要介紹了CSS 中的六個重要選擇器(三秒就可以記住),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-27







