巧用CSS属性值正则匹配选择器(小技巧)

  发布时间:2020-03-11 16:07:13   作者:七年就是一辈子   我要评论
这篇文章主要介绍了巧用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; } ' : '';
});

到此这篇关于巧用CSS属性值正则匹配选择器(小技巧)的文章就介绍到这了,更多相关CSS属性值正则匹配内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

相关文章

  • css3的focus-within选择器的使用

    这篇文章主要介绍了css3的focus-within选择器的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习
    2020-05-11
  • CSS选择器中的正则表达式使用

    这篇文章主要介绍了CSS选择器中的正则表达式使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学
    2020-03-11
  • css选择器四大类:基本、组合、属性、伪类

    这篇文章主要介绍了css选择器四大类:基本、组合、属性、伪类的相关知识,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-14
  • css复杂选择器及css字体样式、颜色属性详解

    这篇文章主要介绍了css复杂选择器及css字体样式、颜色属性,复杂选择有三种,每种方法通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-01-19
  • 详解如何使用CSS3中的结构伪类选择器和伪元素选择器

    这篇文章主要介绍了详解如何使用CSS3中的结构伪类选择器和伪元素选择器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面
    2020-01-06
  • CSS3 新增选择器的实例

    这篇文章主要介绍了CSS3 新增选择器的实例,需要的朋友可以参考下
    2019-11-13
  • css3 伪类选择器快速复习小结

    如果说 css 作为前端开发的基本功, 那么 "选择器" 就是基础中的基础,本文介绍了css3 伪类选择器快速复习,文中通过示例代码介绍的非常详细,对大家的学习或者工
    2019-09-10
  • CSS 样式的使用方式、选择器

    这篇文章主要介绍了CSS 样式的使用方式、选择器 的相关资料,需要的朋友可以参考下
    2019-08-12
  • 盘点CSS Selectors Level4中新增的选择器

    CSS 选择器在实践中是非常常用的,无论是在写样式上或是在 JS 中选择 DOM 元素都需要用到。在 CSS Selectors Level 4 中,工作组继续为选择器标准添加了更丰富的选择器。需
    2018-12-24
  • CSS 中的六个重要选择器(三秒就可以记住)

    这篇文章主要介绍了CSS 中的六个重要选择器(三秒就可以记住),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-27

最新评论