属性值正则匹配选择器包括下面3种:
[attr^="val"] [attr$="val"] [attr*="val"]这3种属性选择器是字符匹配,而非单词匹配。其中,尖角符号 ^ 、 美元 符号 $ 以及星号 * 都是正则表达式中的特殊标识符,分别表示前匹配、后匹配和任意匹配。
利用 这些选择器,纯CSS就可以 做出 很炫酷的功能。
<!-- more -->
显示超链接的小图标和 文件类型 图表
利用 [attr^="val"] 前匹配选择器可以判断 <a> 元素的链接地址类型,以用来显示对应的小图标。显示超链接的小图标的样式如下:
[ hr ef] {padding-left: 18px;} /* 链接地址 */ [href^="https"], [href^="//"] { background: url("./images/link.png") no-re PE at left; } /* 网页内 锚 链 */ [href^=" # "] { background: url("./images/anchor.png") no-repeat left; } /* 手机和邮箱 */ [href^="tel:"] { background: url("./images/tel.png") no-repeat left; } [href^=" ;m ai lto:"] { background: url("./images/e-mail.png") no-repeat left; }
效果
而利用 [attr$="val"] 后匹配选择器则可以实现显示 文件类 型小图标。CSS如下:
/* 指向 PDF文件 */ [href$=".p DF "] { 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属性选择器搜索过滤技 术
我们可以借助属性选择器来辅助我们实现搜索过滤效果,如 通讯录 、城市列表,这样做性能高,代码少。
HT ML 结构如下:
<input type="se Arch " id="input" placeholder="输入城市名称或拼音" /> <ul> <li data -s earch="重庆市 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代码就可以实现搜索匹配效果了,无需自己写代码进行匹配验证。
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 +'"]) { dis play : none; } ' : ''; });
到此这篇关于巧用CSS属性值正则匹配选择器(小技巧)的 文章 就介绍到这了,更多相关CSS属性值正则匹配内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
总结
以上是 为你收集整理的 巧用CSS属性值正则匹配选择器(小技巧) 全部内容,希望文章能够帮你解决 巧用CSS属性值正则匹配选择器(小技巧) 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于巧用CSS属性值正则匹配选择器(小技巧)的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did201053