深入学习jQuery选择器系列第五篇——过滤选择器之内容选择器

×

目录

[1]contains [2]empty [3]parent[4]has[5]not

前面的话

  本文介绍过滤选择器中的内容选择器。内容选择器的过滤规则主要体现在它所包含的子元素或文本内容上

:contains(text)

  :contains(text)选择器选择含有文本内容为‘text‘的元素,返回集合元素

//返回所有文本内容包含‘test‘的元素
$(‘:contains("test")‘)

//返回所有文本内容包含‘test‘的span元素
$(‘span:contains("test")‘)

  该选择器并没有对应的CSS选择器,如果使用javascript实现类似$(‘span:contains("test")‘).css(‘color‘,‘red‘)的效果

var spans = document.getElementsByTagName(‘span‘);
for(var i = 0; i < spans.length; i++){
    if(/test/.test(spans[i].innerHTML)){
        spans[i].style.color = ‘red‘;
    }
}

  [注意]如果:contains(text)选择器中的文本内容text包含在子元素中也可以,但是要小心使用

  【1】$(‘div span:contains("test")‘).css(‘color‘,‘blue‘)可以匹配<div><span><i>test</i></span></div>,但实际上匹配的是<span>元素,<i>元素由于是<span>元素的子元素,所以i元素的文本颜色变为蓝色

  【2】$(‘div :contains("test")‘).css(‘color‘,‘red‘)也可以匹配<div><span><i>test</i></span></div>,但直接匹配的是<i>元素,所以i元素的文本元素变为红色。如果两个选择器同时存在,则文本元素为红色。因为直接给元素设置颜色比通过父级继承颜色的优先级高

<button id="btn1" style="color: red;">$(‘div :contains("test")‘)</button>
<button id="btn2" style="color: blue;">$(‘div span:contains("test")‘)</button>
<button id="reset">还原</button>
<div>
    <span>test1</span>
    <span>test2</span>
    <span><i>test3</i></span>
    <i><span>test4</span></i>
    <i>test5</i>
    <i>1</i>
</div>
<script>
reset.onclick = function(){history.go();}
//对于test3,就是上面讨论的直接给元素设置颜色比通过父级继承颜色的优先级高的情况
btn1.onclick = function(){$(‘div :contains("test")‘).css(‘color‘,‘red‘);}
btn2.onclick = function(){$(‘div span:contains("test")‘).css(‘color‘,‘blue‘);}
</script> 

:empty

  :empty选择器选择不包含子元素或文本的空元素,返回集合元素

$(‘div :empty‘).css(‘color‘,‘red‘);

  对应的CSS选择器是:empty选择器,该选择器选择没有子元素的元素,而且该元素也不包含任何文本节点

:empty{color:red;}

  如果使用javascript实现类似效果

var divs = document.getElementsByTagName(‘div‘);
for(var i = 0; i < divs.length; i++){
    if(divs[i].innerHTML == ‘‘){
        divs[i].style.color = ‘red‘;
    }
}

:parent

  与:empty选择器正好相反,:parent选择器选择含有子元素或文本的元素,返回集合元素

$(‘div :parent‘).css(‘color‘,‘red‘);

  该选择器并没有对应的CSS选择器,如果使用javascript实现类似效果

var divs = document.getElementsByTagName(‘div‘);
for(var i = 0; i < divs.length; i++){
    if(divs[i].innerHTML != ‘‘){
        divs[i].style.color = ‘red‘;
    }
}  
<style>
div div{height: 20px;width: 20px;}
</style>

<button id="btn1" style="color: red;">$(‘div :empty‘)</button>
<button id="btn2" style="color: blue;">$(‘div :parent‘)</button>
<button id="reset">还原</button>
<div>
    <div></div>
    <div>1</div>
    <div>2</div>
    <div>3</div>
</div>
<script>
reset.onclick = function(){history.go();}
btn1.onclick = function(){$(‘div :empty‘).css(‘backgroundColor‘,‘red‘);}
btn2.onclick = function(){$(‘div :parent‘).css(‘backgroundColor‘,‘blue‘);}
</script> 

:has(selector)

  :has(selector)选择器选择含有选择器所匹配的元素的父元素,返回集合元素

  [注意]该选择器匹配的实际上是父元素 

//选择拥有.test的子元素的父元素
$(:has(.test))

//选择拥有.test的子元素的父元素,且该父元素是div元素
$(div:has(.test))

  该选择器没有对应的CSS选择器,如果使用javascript实现类似$(div:has(.test)).css(‘color‘,‘red‘)的效果

var divs = document.getElementsByTagName(‘div‘);
for(var i = 0; i < divs.length; i++){
    var tags = divs[i].getElementsByTagName(‘*‘);
    for(var j = 0; j < tags.length; j++){
        if(tags[j].className == ‘test‘){
            divs[i].style.color = ‘red‘;
            break;
        }
    }
} 

:not(selector)

  :not(selector)选择器去除所有选择器所匹配的元素,返回集合元素

//选择去除.test后的所有span元素
$(span:not(.test))

//选择父元素为div元素下的去除.test后的所有span元素
$(div span:not(.test))

  该选择器没有对应的CSS选择器,如果使用javascript实现类似$(div span:not(.test)).css(‘color‘,‘red‘)的效果

var divs = document.getElementsByTagName(‘div‘);
for(var i = 0; i < divs.length; i++){
    var spans = divs[i].getElementsByTagName(‘span‘);
    for(var j = 0; j < spans.length; j++){
        if(spans[j].className != ‘test‘){
            divs[i].spans[j].style.color = ‘red‘;
        }
    }
}
<style>
div{height: 40px;width: 30px;}
</style>

<button id="btn1" style="color: red;">$(‘div:has(.test)‘)</button>
<button id="btn2" style="color: blue;">$(‘span:has(.test)‘)</button>
<button id="btn3" style="color: green;">$(‘span:not(.test)‘)</button>
<button id="btn4" style="color: pink;">$(‘div:not(.test)‘)</button>
<button id="reset">还原</button>
<div>
    <span class="test">1.1</span>
    <span>1.2</span>
</div>
<div>
    <span>2.1</span>
    <span>2.2</span>
</div>
<script>
reset.onclick = function(){history.go();}
//选择含有.test子元素的div父元素,则第1个div的字体颜色变红
btn1.onclick = function(){$(‘div:has(.test)‘).css(‘backgroundColor‘,‘red‘);} 

//选择含有.test子元素的span父元素,结果span元素下并没有子元素,所以无变化
btn2.onclick = function(){$(‘span:has(.test)‘).css(‘backgroundColor‘,‘blue‘);}

//选择去除.test的span元素,则结果是1.2、2.1、2.2
btn3.onclick = function(){$(‘span:not(.test)‘).css(‘backgroundColor‘,‘green‘);} 

//选择 去除.test的div元素,由于两个div元素都没有.test,所以全部选中
btn4.onclick = function(){$(‘div:not(.test)‘).css(‘backgroundColor‘,‘pink‘);}
</script> 
时间: 2024-08-05 15:18:28

深入学习jQuery选择器系列第五篇——过滤选择器之内容选择器的相关文章

深入学习jQuery选择器系列第四篇——过滤选择器之属性选择器

× 目录 [1]简单属性 [2]具体属性 [3]条件属性 前面的话 属性过滤选择器的过滤规则是通过元素的属性来获取相应的元素,对应于CSS中的属性选择器.属性过滤选择器可分为简单属性选择器.具体属性选择器和条件属性选择器三种.本文将详细该部分内容 简单属性选择器 [attribute] [attribute]选择器选择拥有该属性的元素,返回集合元素 //选择拥有title属性的所有元素 $('[title]') //选择拥有title属性的所有span元素 $('span[title]') //

深入学习jQuery选择器系列第六篇——过滤选择器之状态选择器

× 目录 [1]焦点状态 [2]哈希状态 [3]动画状态[4]显隐状态 前面的话 过滤选择器的内容非常多,本文介绍过滤选择器的最后一部分——状态选择器 焦点状态 :focus :focus选择器选择当前获得焦点的元素 <div> <button>btn1</button> <button>btn2</button> <button>btn3</button> </div> <script> docu

深入学习 jQuery 选择器系列第三篇——过滤选择器之索引选择器 - 小火柴的蓝色理想 - 博客园

博客地址:   http://www.cnblogs.com/xiaohuochai/p/5807292.html#3559878 写的很细致的博文, 手动收藏+转发.

深入学习jQuery选择器系列第八篇——过滤选择器之伪子元素选择器

× 目录 [1]通用形式 [2]反向形式 [3]首尾元素 [4]唯一元素 前面的话 本文是子元素选择器的续篇,主要介绍关于nth-of-type()选择器的内容.该部分内容并非没有出现在<锋利的jQuery>一书中,nth-of-type()选择器参照CSS中的nth-of-type选择器,于1.9版本新增,本文将详细介绍该内容 通用形式 :nth-of-type() 个人认为,:nth-of-type()选择器不应该归类于子元素选择器,也不完全等同索引选择器,因为其索引是指特定元素的索引,但

jquery选择器之内容选择器

HTML示例代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <!--HTML区域--> <h1>第一个标题</h1> <div class="nav-2014">

互联网神经学系列第五篇:研究大脑中的谷歌,脸书和华为思科路由,脑互联网生理学

本文是互联网神经学系列第五篇-"大脑中的类互联网应用和结构,脑互联网生理学" 一.人类大脑研究的困境 大脑的秘密一直是科学皇冠上最明亮的宝石之一,但在两千年前,人们确连它的重要意义还不知道,例如著名的亚里士多德(Aristotle,公元前384-前322)认为神智在心,是心控制着我们的思想,情绪.大约公元前5世纪,地中海科斯岛上托名希波克拉底(Hippocrates)的一群医生被认为是最早发现了脑是神智的载体,在希波克拉底著作中有如下一段话."人们应当认识到:我们的愉悦.欢乐

前端工程师技能之photoshop巧用系列第五篇——雪碧图

显示目录 目录 [1]定义 [2]应用场景 [3]合并[4]实现[5]维护 前面的话 前面已经介绍过,描述性图片最终要合并为雪碧图.本文是photoshop巧用系列第五篇--雪碧图 定义 css雪碧图(sprite)是一种网页图片应用处理方式,它允许将一个页面涉及到的所有零星图片都包含到一张大图中.使用雪碧图的处理方式可以实现两个优点: [1]减少http请求次数 [2]减少图片大小,提升网页加载速度 (多张图片加载速度小于拼合成的图片的加载速度) 凡事都不完美,实现优点的同时也带来了缺点,即提

CSS3 选择器之基本选择器

CSS是一种用于屏幕上渲染html,xml等一种语言,CSS主要是在相应的元素中应用样式,来渲染相对应用的元素,那么这样我们选择相应的元素就很重要了,如何选择对应的元素,此时就需要我们所说的选择器.选择器主要是用来确定html的树形结构中的DOM元素节点. CSS3的常用选择器有: 下面举几个例子来说明选择器的实用方法: 1.创建如下的DOM结构: <div class="demo"> <ul class="clearfix"> <li

【Windows编程】系列第五篇:GDI图形绘制

上两篇我们学习了文本字符输出以及Unicode编写程序,知道如何用常见Win32输出文本字符串,这一篇我们来学习Windows编程中另一个非常重要的部分GDI图形绘图.Windows的GDI函数包含数百个API可供我们使用,本篇把最常用的GDI绘图做一个讲解.GDI可以绘制点.直线曲线.填充封闭区域.位图以及文本,其中文本部分已经在上一篇中将了,请参考[Windows编程]系列第三篇:文本字符输出. 跟前面的GDI对象一样,本篇的这些绘图函数也必须要设备上下文句柄(HDC)作为函数参数,从前文我