关键词:
层级选择器
如果两个DOM元素具有祖先后代的关系,就可以用$(‘ancestor descendant‘)来选择
父亲也是祖先
选择器中的属性选择用中括号括起来[]
$(‘ul.lang li.lang-javascript‘); // [<li class="lang-javascript">JavaScript</li>]
$(‘div.testing li.lang-javascript‘); // [<li class="lang-javascript">JavaScript</li>]
$(‘form[name=upload] input‘);
多层选择也是允许的:
$(‘form.test p input‘); // 在form表单选择被<p>包含的<input>
子选择器(Child Selector)
父子关系:$(‘parent>child‘)
过滤器(Filter)
过滤器一般不单独使用,它通常附加在选择器上,帮助我们更精确地定位元素。观察过滤器的效果:
$(‘ul.lang li‘); // 选出JavaScript、Python和Lua 3个节点
$(‘ul.lang li:first-child‘); // 仅选出JavaScript
$(‘ul.lang li:last-child‘); // 仅选出Lua
$(‘ul.lang li:nth-child(2)‘); // 选出第N个元素,N从1开始
$(‘ul.lang li:nth-child(even)‘); // 选出序号为偶数的元素
$(‘ul.lang li:nth-child(odd)‘); // 选出序号为奇数的元素
$(‘div:visible‘); // 所有可见的div
$(‘div:hidden‘); // 所有隐藏的div
表单相关
针对表单元素,jQuery还有一组特殊的选择器:
:input:可以选择<input>,<textarea>,<select>和<button>;
:file:可以选择<input type="file">,和input[type=file]一样;
:checkbox:可以选择复选框,和input[type=checkbox]一样;
:radio:可以选择单选框,和input[type=radio]一样;
:focus:可以选择当前输入焦点的元素,例如把光标放到一个<input>上,用$(‘input:focus‘)就可以选出;
:checked:选择当前勾上的单选框和复选框,用这个选择器可以立刻获得用户选择的项目,如$(‘input[type=radio]:checked‘);
:enabled:可以选择可以正常输入的<input>、<select>等,也就是没有灰掉的输入;
:disabled:和:enabled正好相反,选择那些不能输入的。
其他选择器
此外,jQuery还有很多有用的选择器
var a = $(‘.red.green‘); // 注意没有空格!节点有多个class,查找同时包含red和green的节点
$(‘[name=email]‘)
$(‘[name^=icon]‘); // 找出所有name属性值以icon开头的DOM
$(‘[name$=with]‘); // 找出所有name属性值以with结尾的DOM
$(‘input[name=email]‘);//组合查找
$(‘p,div‘); // 把<p>和<div>都选出来//多项选择器:多项选择器就是把多个选择器用,组合起来一块选
$(‘p.red,p.green‘); // 把<p class="red">和<p class="green">都选出来
注意的是,选出来的元素是按照它们在HTML中出现的顺序排列的,而且不会有重复元素。例如,<p class="red green">不会被上面的$(‘p.red,p.green‘)选择两次。
查找和过滤
一般情况,选择器可以直接找到目标元素
但是,当我们先拿到一个祖先jQuery对象后,还可以以这个对象为基准,进行查找和过滤
最常见的查找是在某个节点的所有子节点中查找,使用find()方法,它本身又接收一个任意的选择器
<!-- HTML结构 -->
<ul class="lang">
<li class="js dy">JavaScript</li>
<li class="dy">Python</li>
<li id="swift">Swift</li>
<li class="dy">Scheme</li>
<li name="haskell">Haskell</li>
</ul>
var ul = $(‘ul.lang‘); // 获得<ul>
var dy = ul.find(‘.dy‘); // 获得JavaScript, Python, Scheme find()里面可以传入参数,参数是css选择器
var swf = ul.find(‘#swift‘); // 获得Swift
var hsk = ul.find(‘[name=haskell]‘); // 获得Haskell
如果要从当前节点开始向上查找,使用parent()方法,parent()里面可以传入参数,参数是css选择器
var swf = $(‘#swift‘); // 获得Swift
var parent = swf.parent(); // 获得Swift的上层节点<ul>
var a = swf.parent(‘.red‘); // 获得Swift的上层节点<ul>,同时传入过滤条件。如果ul不符合条件,返回空jQuery对象
对于位于同一层级的节点,可以通过next()和prev()方法,next()和prev()里面可以传入参数,参数是css选择器
var swift = $(‘#swift‘);
swift.next(); // Scheme
swift.next(‘[name=haskell]‘); // 空的jQuery对象,因为Swift的下一个元素Scheme不符合条件[name=haskell]
swift.prev(); // Python
swift.prev(‘.dy‘); // Python,因为Python同时符合过滤器条件.dy
过滤
jQuery对象就是一个DOM对象数组
filter()里面可以传入参数,参数是css选择器或函数,返回结果是符合条件的传入的参数
var langs = $(‘ul.lang li‘);
var a = langs.filter(‘.dy‘);
或者传入一个函数,要特别注意函数内部的this被绑定为DOM对象,不是jQuery对象:
var langs = $(‘ul.lang li‘);
langs.filter(function ()
return this.innerHTML.indexOf(‘S‘) === 0; // 返回S开头的节点
);
map()里面可以传入参数,参数:是函数 ,返回值是函数的返回值
var langs = $(‘ul.lang li‘);
var arr = langs.map(function ()
return this.innerHTML;
).get(); // 用get()拿到包含string的Array:[‘JavaScript‘, ‘Python‘, ‘Swift‘, ‘Scheme‘, ‘Haskell‘]
此外,jQuery对象如果包含多个DOM对象,first()、last()和slice()方法返回一个新的jQuery对象,把不需要的DOM节点去掉:
var langs = $(‘ul.lang li‘); // 拿到JavaScript, Python, Swift, Scheme和Haskell
var js = langs.first(); // JavaScript,相当于$(‘ul.lang li:first-child‘)
var haskell = langs.last(); // Haskell, 相当于$(‘ul.lang li:last-child‘)
var sub = langs.slice(2, 4); // Swift, Scheme, 参数和数组的slice()方法一致
javascript之jquery-2jquery选择器(jquery选择器基本选择器层次选择器过滤选择器表单选择器)
一、jQuery选择器 jQuery选择器简介 -jQuery选择器类似于CSS选择(定位元素,施加样式),能够实现定位元素,施加行为 -使用jQuery选择器能够将内容与行为分离 -学会使用选择器是学习jQuery的基础jQuery选择器的优势 -... 查看详情
jquery选择器之基本筛选选择
1.基本选择器 2.内容筛选选择器 3.可见性筛选选择器4.属性筛选选择器5.子元素筛选选择器6.表单元素选择器 7.表单对象属性筛选器 查看详情
jquery学习笔记之选择器
目录: 选择器: 选择器应用优化 简单的伪类选择器 内容伪类选择器 显隐伪类选择器 子元素伪类选择器 表单对象伪类选择器 表单属性伪类选择器 ... 查看详情
jquery选择器之层级选择器
选择器描述$("parent>child") 子选择器$("ancestordescendant")后代选择器$("prev+next")相邻兄弟选择器$("prev~siblings")一般兄弟选择器子选择器:选择所指定parent元素指定的child的直接子元素。后代选择器:选择给定的祖先元素的所有后代... 查看详情
jquery选择器之过滤选择器
过滤选择器类似于CSS中的伪类选择器,以冒号开头。过滤选择器根据其过滤规则分为:基本过滤选择器、内容过滤选择器、可见性过滤选择器、属性过滤选择器、子元素过滤选择器、以及表单对象属性过滤选择... 查看详情
锋利的jquery学习笔记之jquery选择器
在介绍jQuery选择器之前,先简单介绍一下CSS选择器--->一、CSS选择器常见的CSS选择器有以下几种:选择器语法描述示例标签选择器E{CSS规则}以文档元素为选择符td{font-size:10px;}a{tetx-decoration:none;}ID选择器#ID{CSS规则}以文档元素的唯... 查看详情
jquery选择器之基本选择器
获得页面各种元素节点1.$(#id属性值)$(‘#useremail‘).css(‘color‘,‘red‘);2. $(tag标签名称)$(‘h2‘).css(‘backgroundColor‘,‘pink‘);$(‘input‘).css(‘backgroundColor‘,‘lightblue‘);3.$(.class属性值)$(‘.pear‘).css(‘fontSize‘,‘3 查看详情
jquery选择器之元素选择器
元素选择器:根据给定(html)标记名称选择所有的元素。描述:$(‘element‘)搜索指定元素标签名的所有节点,这是一个合集的操作。同样的也有原生方法getElementsByTagName()函数支持。第一组:通过getElementsByTagName方法得到页面所... 查看详情
jquery之过滤选择器
过滤选择器 1.基本选择器 2.内容选择器 3.可见性选择器 4.子元素过滤器 过滤选择器简称:过滤器。它其实也是一种选择器,而这种选择器类似于CSS3(http://t.mb5u.com/css3/)里的伪类,可以让不支持CSS3的浏览器也能支... 查看详情
jquery之基本选择器(代码片段)
1.是什么?-有特定格式的字符串2.作用-用来查找特定页面元素3.基本选择器-#id:id选择器-element:元素选择器-.class:属性选择器-*:任意标签-selector1,selector2,selectorN:取多个选择器的并集(组合选择器)-selector1selector2selectorN:取多个选择器的... 查看详情
jquery选择器之属性选择器
[attribute] 匹配指定属性名的所有元素 [attribute=value]匹配给定的属性名是某个特定值的属性 [attribute!=value] 匹配给定的属性名不是某个特定值的属性 [attribute^=value]以开头 [attribute$=value]以结尾 [attribue*=... 查看详情
jquery选择器之层级选择器
<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><linkrel="stylesheet"href="imooc.css"type="text/css"> 查看详情
jquery选择器之层级选择器
<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><linkrel="stylesheet"href="imooc.css"type="text/css"> 查看详情
jquery选择器之元素选择器
<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><style>div{width:100px;height:90px;float:left;paddin 查看详情
jquery选择器之内容选择器
HTML示例代码<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title></title></head><body><!--HTML区域--><h1>第一个标题</h1><divclass="n 查看详情
jquery选择器之属性筛选选择器
在这么多属性选择器中[attr="value"]和[attr*="value"]是最实用的[attr="value"]能帮我们定位不同类型的元素,特别是表单form元素的操作,比如说input[type="text"],input[type="checkbox"]等[attr*="value"]能在网站中帮助我们匹配不同类型的文件<!DOC... 查看详情
jquery选择器之表单元素选择器
<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><linkrel="stylesheet"href="imooc.css"type="text/css"> 查看详情
深入学习jquery选择器系列第四篇——过滤选择器之属性选择器
×目录[1]简单属性[2]具体属性[3]条件属性前面的话 属性过滤选择器的过滤规则是通过元素的属性来获取相应的元素,对应于CSS中的属性选择器。属性过滤选择器可分为简单属性选择器、具体属性选择器和条件属性选择器... 查看详情