白云岛资源网 Design By www.pvray.com
属性值正则匹配选择器包括下面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; } ' : ''; });
白云岛资源网 Design By www.pvray.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
白云岛资源网 Design By www.pvray.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。