您好,欢迎访问一九零五行业门户网

jQuery三种$()使用详解

这次给大家带来jquery三种$()使用详解,jquery三种$()使用的注意事项有哪些,下面就是实战案例,一起来看一下。
$号是jquery“类”的一个别称,$()构造了一个jquery对象。所以,“$()”可以叫做jquery的构造函数(个人观点,呵呵!)。
1、$()可以是$(expresion),即css选择器、xpath或html元素,也就是通过上述表达式来匹配目标元素。
比如:$(a)构造的这个对象,是用css选择器构建了一个jquery对象——它选择了所有的<a/>这个标签。如:
$(a).click(function(){...})
就是在点击页面上的任何一个链接时的触发事件。确切地说,就是jquery用<a/>这个标签构建了一个对象$(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对象,然后向<body/>中添加这一字串。
2、$()可以是$(element),即一个特定的dom元素。如常用的dom对象有document、location、form等。如这样一行代码:
$(document).find(p>p).html());
$()中的document是一个dom元素,即在全文寻找带<p>的<p>元素,并显示<p>中的内容。
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>;
而$('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>;而$('p ul')是在<p>的所有后代里找<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]
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
html常用的属性知识点总结
h5设计时的小技巧总结
h5+c3+js实现楼层跳跃特效
以上就是jquery三种$()使用详解的详细内容。
其它类似信息

推荐信息