jQuery的三种$()
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jQuery的三种$()相关的知识,希望对你有一定的参考价值。
$(‘div>ul‘)是<div>的直接后代里找<ul>;
而$(‘div ul‘)是在<div>的所有后代里找<ul>。
1.用来的作为html的Dom选择器
$(selector).action()
(selector):用于查询html元素
action():执行对元素的操作
而 $("div p") :选择div元素下的所有p元素
$("div #p"):div 下 所有的id="p"的元素
$("div .p"):div下所有的class="p"的元素
当选择器selector中的元素职之间没空格分离的时候:
eg: $div("div.pp") 选取class="pp"的所有div;
$div("div#pp") 选取id="pp"的所有的div;
举一反三: $(.pp#dd) 和 $(.pp.dd) 是否成立? //不成立! 要实现这样的不能连写,只有前部分是html标签才可以, $(.pp #dd) 和$(#dd #pp)是可行的,选择id="dd" 下id="pp"的元素;
2.$()中的是一个查询表达式
对于选择HTML文档中的elements,jQuery有两种方法:
1、标签选择器$(‘p‘)
如$("div>ul a"),它的意思是div标签中的ul标签中的a标签
不过,$(‘div>ul‘)和$(‘div ul‘)是有区别的
$(‘div>ul‘)是<div>的直接后代里找<ul>;而$(‘div ul‘)是在<div>的所有后代里找<ul>。
所以,$(‘#sId>li‘)所选择的是id为"sId"的所有<li>孩子节点,即使这个<li>的后代还有<li>也不是它所找的范围(所找到的DOM对象,只是它本级的DOM对象。)。而$(‘#sId li:not(.horizontal)‘),就是指类名"sId"里面的所有li的子孙中没有horizontal类的所有元素。——这里的not()是一个negation pseudo class.
这里返回的是一个jQurey对象,一个数组对象,这个jQuery对象的长度可用.length()得到。
2、XPath选择器
如:选择所有带有title 属性的链接,我们会这样写:$(‘a[@title]‘)
[]里带@,说明[]里的是元素的属性;是个属性选择器
[]里没@,说明[]里的是元素的子孙。
$(‘ul li‘)和$(‘ul[li]‘)虽然返回的都是一个jQuery数组,但两者的含义正好相反。前者是要找<ul>下所有<li>子孙,而后者却是在找所有子孙为<li>的<ul>数组。
在XPath中,要找一个“以...开头”的属性,用^=,如找一个name属性是以mail开头的input元素,就用
$(‘input[@name^="mail"]‘)
要找一个“以...结尾”的属性,要用$=
要找一个“不头不尾”的属性,用*=
3、不属于上述的CSS和XPath的选择器,就是自定义的选择器了,用“:”表示,这里要用的就是:first,:last,:parent ,:hidden,:visible,:odd,:even,:not(‘xxx‘), ":eq(0)"(始于0),:nth(n),:gt(0),:lt(0),:contains("xxx")
如:$(‘tr:not([th]):even‘)意为<tr>元素的子孙中不含<th>的所有子孙的偶数项
4、还有几个,简单不解释了
$(‘th‘).parent()——
$(‘td:contains("Henry")‘).prev()——内容包含有"Henry"的<td>的上一个节点
$(‘td:contains("Henry")‘).next()——内容包含有"Henry"的<td>的下一个节点
$(‘td:contains("Henry")‘).siblings()——内容包含有"Henry"的<td>的所有兄弟节点
还有一个,就是end(),这个方法肯定是用在某个DOM节点执行了某一动作之后,还想在与其相关的节点上执行类似动作,这里就要用到end()。用过end()方法之后,所返回的是执行动作的那个节点的父节点上。举个例子
$(...).parent().find(...).addClass().end()
这里执行动作的节点是find(...),是一个数组对象,它所做的动作是“addClass()”,之后,用了个end(),这时所返回的东东就是指向了parent()所指向的节点,也就是执行“addClass()”动作的那个数组对象的父节点。
5、要直接访问DOM元素,可用get(0)的方法,如
$(‘#myelement‘).get(0),也可缩写成$(‘#myelement‘)[0]
以上是关于jQuery的三种$()的主要内容,如果未能解决你的问题,请参考以下文章