jQuery三種$()使用詳解
- php中世界最好的语言原創
- 2018-04-20 09:08:592251瀏覽
這次帶給大家jQuery三種$()使用詳解,jQuery三種$()使用的注意事項有哪些,下面就是實戰案例,一起來看一下。
$號是jQuery「類別」的一個別稱,$()建構了一個jQuery物件。所以,「$()」可以叫做jQuery的建構子(個人觀點,呵呵!)。
1、$()可以是$(expresion),也就是css選擇器、Xpath或html元素,也就是透過上述表達式來符合目標元素。
例如:$("a")建構的這個對象,是用CSS選擇器建構了一個jQuery物件-它選擇了所有的這個標籤。如:
$("a").click(function(){...})
就是在點擊頁面上的任何一個連結時的觸發事件。確切地說,就是jQuery用這個標籤建構了一個物件$("a"),函數 click()是這個jQuery物件的一個(事件)方法。
例如有這樣一段HTML程式碼:
<p>one</p>
<p>
<p>two</p>
</p>
<p>three</p>
<a href="#" id="test" onClick="jq()" >jQuery</a>
而操作這段HTML的是如下一條語句:
alert($("p>p").html());
$()中的是一個查詢表達式,也就是用“ p>p」這樣一個查詢表達式建構了一個jQuery對象,然後的「html()」意思是顯示其html內容,也就是上面HTML程式碼段的[two]。再如:
$("<p><p>Hello</p></p>").appendTo("body");
$()中的是一個字串,用這樣一段字符串建構了jQuery對象,然後在
中加入這一字符串。
2、$()可以是$(element),也就是一個特定的DOM元素。如常用的DOM物件有document、location、form等。如這樣一行程式碼:
$(document).find("p>p").html());
$()中的document是一個DOM元素,即在全文中尋找帶有
的
元素,並顯示
中的內容。
3、$()可以是$(function),也就是一個函數,它是$(document).ready()的一個速記方式。如常見的形式是這樣的:
$(document).ready(function(){
alert("Hello world!");
});
可變形作:
$(function(){
alert("Hello world!");
});
对于选择HTML文档中的elements,jQuery有两种方法:
1)如$("p>ul a"),它的意思是p标签中的ul标签中的a标签
不过,$('p>ul')和$('p ul')是有区别的,
$('p>ul')是
的直接后代里找
;
而$('p ul')是在的所有后代里找
。
2)用jQuery对象的几个方法(如方法find()、each()等)
$("#orderedlist).find("li") 就像 $("#orderedlist li"). each()一样迭代了所有的li,而表达式中的“#”表示HTML中的ID,如上例中的“#orderedlist”就表示“ID为orderedlist所在的标签”。
****************************************************************
1、标签选择器$('p')、类选择器$('.myClass')、id选择器$('#myId')相对简单,不多说。不过有一点——$('p>ul')和$('p ul')是有区别的,
$('p>ul')是的直接后代里找
;而$('p ul')是在的所有后代里找
。
所以,$('#sId>li')所选择的是id为"sId"的所有- 孩子节点,即使这个
- 的后代还有
- 也不是它所找的范围(所找到的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数组,但两者的含义正好相反。前者是要找下所有- 子孙,而后者却是在找所有子孙为
- 的
数组。
在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')意为元素的子孙中不含的所有子孙的偶数项 4、还有几个,简单不解释了 $('th').parent()—— $('td:contains("Henry")').prev()——内容包含有"Henry"的 | 的上一个节点 $('td:contains("Henry")').next()——内容包含有"Henry"的 | 的下一个节点 $('td:contains("Henry")').siblings()——内容包含有"Henry"的 | 的所有兄弟节点 还有一个,就是end(),这个方法肯定是用在某个DOM节点执行了某一动作之后,还想在与其相关的节点上执行类似动作,这里就要用到end()。用过end()方法之后,所返回的是执行动作的那个节点的父节点上。举个例子 $(...).parent().find(...).addClass().end() 这里执行动作的节点是find(...),是一个数组对象,它所做的动作是“addClass()”,之后,用了个end(),这时所返回的东东就是指向了parent()所指向的节点,也就是执行“addClass()”动作的那个数组对象的父节点。 5、要直接访问DOM元素,可用get(0)的方法,如 $('#myelement').get(0),也可缩写成$('#myelement')[0]
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
HTML常用的属性知识点总结
H5设计时的小技巧总结
H5 C3 JS實現樓層跳躍特效
以上是jQuery三種$()使用詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章! 陳述:本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn |