属性值正则匹配选择器包括下面3种:css
这3种属性选择器是字符匹配,而非单词匹配。其中,尖角符号^
、美圆符号$
以及星号*
都是正则表达式中的特殊标识符,分别表示前匹配、后匹配和任意匹配。html
利用这些选择器,纯CSS就能够作出很炫酷的功能。web
利用[attr^="val"]
前匹配选择器能够判断<a>
元素的连接地址类型,以用来显示对应的小图标。显示超连接的小图标的样式以下:正则表达式
[href] {padding-left: 18px;}
/* 连接地址 */
[href^="https"],
[href^="//"] {
background: url("./images/link.png") no-repeat left;
}
/* 网页内锚链 */
[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;
}
复制代码
效果app
而利用[attr$="val"]
后匹配选择器则能够实现显示文件类型小图标。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;
}
复制代码
效果以下ui
咱们能够借助属性选择器来辅助咱们实现搜索过滤效果,如通信录、城市列表,这样作性能高,代码少。this
HTML结构以下:url
<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>
复制代码
此时,当咱们在输入框种输入内容的时候,只要根据输入内容动态建立一段CSS代码就能够实现搜索匹配效果了,无需本身写代码进行匹配验证。spa
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; } ' : '';
});
复制代码
最终效果以下
关注公众号,第一时间接收最新文章。若是对你有一点点帮助,能够点喜欢点赞点收藏,还能够小额打赏做者,以鼓励做者写出更多更好的文章。