JQuery Tips(3) 关于$()包装集内元素的改变


Posted in Javascript onDecember 14, 2009

这两个方法是比较容易搞混的.
filter方法表示的是对当前内部的元素进行筛选,这个接受两种参数,一个返回bool的function,或者是JQuery的选择表达式,包装集内的元素只会小于等于当前包装集内的元素,并且含有的元素属于原来包装集内元素的子集:

<div id="one">the one</div> 
<div id="two"><p>the two</p></div> 
<div id="three"><p>the three</p></div> 
<script type="text/javascript"> 
alert($("div").filter(":not(:first):not(:last)").html()); //out put<p>the two</p> 
alert($("div").filter(function() { return this.id == "two"; }).html());//output <p>the two</p> as well 
</script>

而find方法却是在当前元素内(子元素)部进行查找,并返回新的包装集,这意味着包装集可能会增加:
<div id="one">the one</div> 
<div id="two"><p>the two</p><p></p><p></p></div> 
<div id="three"><p>the three</p></div> 
<script type="text/javascript"> 
alert($("div").find("p").text()); //alert "the twothe three" 
alert($("div").find("p").length); //alert 4 instead of original 3 
</script>

从上面可以看出新包装集内的元素增加了

parents()方法 VS closest()方法
这两个方法都是由当前元素向上查找所匹配的元素,不同之处如下:

<div id="wrapper"> 
<div id="two"> 
<p id="p1"> 
the two</p> 
</div> 
</div> 
<script type="text/javascript"> 
alert($("#p1").parents("div").length); //alert 2 include <div id="two"> and <div id="wrapper"> 
alert($("#p1").closest("div").length); //alert 1 and only include <div id="two"> 
alert($("#p1").parents("p").length); //alert 0 because it does not include current element 
alert($("#p1").closest("p").length); //alert 1 because it contain itself <p id="p1"> 
</script>

对于parents方法来说,会将当前元素向上的所有匹配元素加入新的包装集并返回,而closest方法只会包含离当前元素最近的元素,所以使用closest方法后当前包装集内的元素只能为1个或者0个
而parents方法并不包括当前包装集内的元素,而closest方法会包含当前包装集内的元素
直系子元素 VS 所有子元素
使用children可以返回直系子元素,而用find加通配符的方法可以返回除了文本节点之外的所有子元素:
<div id="wrapper"> 
text node here 
<div id="two"> 
<p id="p1"> 
the two</p> 
</div> 
</div> 
<script type="text/javascript"> 
alert($("#wrapper").children().length);//alert 1 because only direct children included 
alert($("#wrapper").find("*").length); //alert 2 because all desendants included 
alert($("#wrapper").find(">*").length);//alert 1 because only direct children included 
</script>

可以看出children方法只会含有当前元素的直系子元素,而使用find(“>*也会产生同样的效果”).若想采纳所有的直系子元素直接在find内传”*”通配符
回到过去的end()方法以及andself()方法
上述所有的方法,以及比如add(),next(),nextAll(),prev()等对包装集内元素进行改变的方法都可以使用end()方法来进行返回:
<div id="wrapper"> 
text node here 
<div id="two"> 
<p id="p1"> 
the two</p> 
</div> 
</div> 
<script type="text/javascript"> 
alert($("#wrapper").find(">*").end().get(0).id);//alert "wrapper" instead of "two" because of end() method has been used 
</script>

end()方法总是和最近的一个和包装集改变的方法相抵消,而抵消其他方法:
<div id="wrapper"> 
text node here 
<div id="two"> 
<p id="p1"> 
the two</p> 
</div> 
</div> 
<script type="text/javascript"> 
alert($("#wrapper").find("#p1").html("new value").end().get(0).id);//alert wrapper because end method 
alert($("#p1").text())//alert new value bacause the html method in previous has not been cancelled 
</script>

如果需要在改变包装集内元素的情况下还需要包含原始的包装集内元素,使用andself方法:
<div id="wrapper"> 
text node here 
<div id="two"> 
<p id="p1"> 
the two</p> 
</div> 
</div> 
<script type="text/javascript"> 
var $a = $("#wrapper").find("#two").andSelf(); 
alert($a[0].id);//alert two first 
alert($a[1].id);//alert wrapper after that 
</script>

我们会发现首先alert two,因为two先被选择

PS:liver writer代码高亮插件我一加中文就是乱码,很郁闷的说-.-!!所以注释都是鸟语了

Javascript 相关文章推荐
对YUI扩展的Gird组件 Part-2
Mar 10 Javascript
一个简单的js鼠标划过切换效果
Jun 30 Javascript
jQuery筛选器children()案例详解(图文)
Feb 17 Javascript
javascript代码运行不出来执行错误的可能情况整理
Oct 18 Javascript
JS+CSS实现DIV层的展开、收缩效果
Jan 28 Javascript
浅谈jquery选择器 :first与:first-child的区别
Nov 20 Javascript
jQuery实现鼠标滑过预览图片大图效果的方法
Apr 26 jQuery
JavaScript的六种继承方式(推荐)
Jun 26 Javascript
详解@angular/cli 改变默认启动端口两种方式
Nov 29 Javascript
微信小程序实现购物页面左右联动
Feb 15 Javascript
js实现石头剪刀布游戏
Oct 11 Javascript
Vue自定义表单内容检查rules实例
Oct 30 Javascript
JQuery Tips(2) 关于$()包装集你不知道的
Dec 14 #Javascript
js 页面传参数时 参数值含特殊字符的问题
Dec 13 #Javascript
JQuery下关于$.Ready()的分析
Dec 13 #Javascript
javascript与asp.net(c#)互相调用方法
Dec 13 #Javascript
JavaScript 字符串与数组转换函数[不用split与join]
Dec 13 #Javascript
jQuery 行背景颜色的交替显示(隔行变色)实现代码
Dec 13 #Javascript
页面中iframe相互传值传参
Dec 13 #Javascript
You might like
很温暖很温暖的Lester Young
2021/03/03 冲泡冲煮
php中读写文件与读写数据库的效率比较分享
2013/10/19 PHP
php动态生成版权所有信息的方法
2015/03/24 PHP
PHP中返回引用类型的方法
2015/04/03 PHP
PHP使用PDO操作sqlite数据库应用案例
2019/03/07 PHP
PHP实现简易图形计算器
2020/08/28 PHP
推荐20家国外的脚本下载网站
2011/04/28 Javascript
改变文件域的样式实现思路同时兼容ie、firefox
2013/10/23 Javascript
jQuery UI插件自定义confirm确认框的方法
2015/03/20 Javascript
微信小程序实现指定显示行数多余文字去掉用省略号代替
2018/07/25 Javascript
AngularJS $http post 传递参数数据的方法
2018/10/09 Javascript
记一次vue-webpack项目优化实践详解
2019/02/17 Javascript
Vue在 Nuxt.js 中重定向 404 页面的方法
2019/04/23 Javascript
详解React 元素渲染
2020/07/07 Javascript
用vite搭建vue3应用的实现方法
2021/02/22 Vue.js
python 把列表转化为字符串的方法
2018/10/23 Python
用python3 返回鼠标位置的实现方法(带界面)
2019/07/05 Python
Django  ORM 练习题及答案
2019/07/19 Python
win10下安装Anaconda的教程(python环境+jupyter_notebook)
2019/10/23 Python
Pandas+Matplotlib 箱式图异常值分析示例
2019/12/09 Python
pytorch实现mnist分类的示例讲解
2020/01/10 Python
Python发送手机动态验证码代码实例
2020/02/28 Python
基于django micro搭建网站实现加水印功能
2020/05/22 Python
python实现npy格式文件转换为txt文件操作
2020/07/01 Python
拿来就用!Python批量合并PDF的示例代码
2020/08/10 Python
Canvas获取视频第一帧缩略图的实现
2020/11/11 HTML / CSS
英国在线照明超市:Castlegate Lights
2019/10/30 全球购物
配件采购员岗位职责
2013/12/03 职场文书
优秀的自荐信要注意哪些
2014/01/03 职场文书
自主招生推荐信怎么写
2015/03/26 职场文书
幼儿园园务工作总结2015
2015/05/18 职场文书
2015年教务工作总结
2015/05/23 职场文书
《活见鬼》教学反思
2016/02/24 职场文书
创业计划书之少年玩具店
2019/09/05 职场文书
详解Redis在SpringBoot工程中的综合应用
2021/10/16 Redis
Win10系统搭建ftp文件服务器详细教程
2022/08/05 Servers