山海科技发展网

08月13日科技常识:巧用CSS属性值正则匹配选择器

导读 摘要 今天小编跟大家讲解下有关巧用CSS属性值正则匹配选择器 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关巧用CSS属性值...
摘要 今天小编跟大家讲解下有关巧用CSS属性值正则匹配选择器 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关巧用CSS属性值正则匹

今天小编跟大家讲解下有关巧用CSS属性值正则匹配选择器 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关巧用CSS属性值正则匹配选择器 的相关资料,希望小伙伴们看了有所帮助。

属性值正则匹配选择器包括下面3种:

[attr^="val"][attr$="val"][attr*="val"]

这3种属性选择器是字符匹配 而非单词匹配。其中 尖角符号^、美元符号$以及星号*都是正则表达式中的特殊标识符 分别表示前匹配、后匹配和任意匹配。

利用这些选择器 纯css就可以做出很炫酷的功能。<!-- more -->

显示超链接的小图标和文件类型图表

利用[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;}

效果

而利用[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;}

效果如下

css属性选择器搜索过滤技术

我们可以借助属性选择器来辅助我们实现搜索过滤效果 如通讯录、城市列表 这样做性能高 代码少。

html结构如下:

<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代码就可以实现搜索匹配效果了 无需自己写代码进行匹配验证。

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; } ' : '';});

来源:爱蒂网