JS中$含义及⽤法
$在JS中本⾝只是⼀个符号⽽异,在JS⾥什么也不是。
但在JS应⽤库JQUERY的作者将之做为⼀个⾃定义函数名了,这个函数是获取指定⽹页元素的函数,使⽤⾮常之频繁,所以好多新⼿不知道,还以为$是JS的什么特殊语法。
后来,可能有些程序员JQUERY⽤得多了,发现$这个函数很好⽤,很⽅便,所以,在不⽤JQUERY的情况,⼀般⾃⼰也会⾃定义⼀个$函数。
即:
function $(Nid){
ElementById(Nid);
}
就这么简单(在JSQUERY⾥可能稍微功能再强⼤⼀点,但主要还是我写的这个功能。)
以后在⽹页就不⽤每次使⽤ElementById("ID名")来获取元素,只⽤$('ID名')即可,⾮常简
使了。
三种具体⽤法:
1、$()可以是$(expresion),即css选择器、Xpath或html元素,也就是通过上述表达式来匹配⽬标元素。
⽐如:$("a")构造的这个对象,是⽤CSS选择器构建了⼀个jQuery对象——它选择了所有的<a/>这个标签。如:
$("a").click(function(){...})
就是在点击页⾯上的任何⼀个链接时的触发事件。确切地说,就是jQuery⽤<a/>这个标签构建了⼀个对象$("a"),函数 click()是这个jQuery对象的⼀个(事件)⽅法。
⽐如有这样⼀段HTML代码:
<p>one</p>
<div>
<p>two</p>
</div>
<p>three</p>
<a href="#" id="test" onClick="jq()">jQuery</a>
⽽操作这段HTML的是如下⼀条语句:
alert($("div>p").html());
$()中的是⼀个查询表达式,也就是⽤“div>p”这样⼀个查询表达式构建了⼀个jQuery对象,然后的“html()”意思是显⽰其html内容,也就是上⾯HTML代码段的[two]。再如:
$("<div><p>Hello</p></div>").appendTo("body");
jquery是什么有什么作用$()中的是⼀个字符串,⽤这样⼀段字串构建了jQuery对象,然后向<body/>中添加这⼀字串。
2、$()可以是$(element),即⼀个特定的DOM元素。如常⽤的DOM对象有document、location、form等。如这样⼀⾏代码:
$(document).find("div>p").html());
$()中的document是⼀个DOM元素,即在全⽂寻带<p>的<div>元素,并显⽰<p>中的内容。
3、$()可以是$(function),即⼀个函数,它是$(document).ready()的⼀个速记⽅式。如常见的形式是这样的:
$(document).ready(function(){
alert("Hello world!");
});
可变形作:
$(function(){
alert("Hello world!");
});
对于选择HTML⽂档中的elements,jQuery有两种⽅法:
1)如$("div>ul a"),它的意思是div标签中的ul标签中的a标签
不过,$('div>ul')和$('div ul')是有区别的,
$('div>ul')是<div>的直接后代⾥<ul>;
⽽$('div ul')是在<div>的所有后代⾥<ul>。
2)⽤jQuery对象的⼏个⽅法(如⽅法find()、each()等)
$("#orderedlist).find("li") 就像 $("#orderedlist li"). each()⼀样迭代了所有的li,⽽表达式中的“#”表⽰HTML中的ID,如上例中的“#orderedlist”就表⽰“ID为orderedlist所在的标签”。
****************************************************************
1、标签选择器$('p')、类选择器$('.myClass')、id选择器$('#myId')相对简单,不多说。不过有⼀点——$('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的⼦孙这⾥返回的是⼀个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]

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。