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 相关文章推荐
js 加载时自动调整图片大小
May 28 Javascript
js判断IE6/IE7/FF的代码[XMLHttpRequest]
Feb 16 Javascript
利用百度地图JSAPI生成h7n9禽流感分布图实现代码
Apr 15 Javascript
jQuery在html有效在jsp无效的原因及解决方法
Aug 02 Javascript
Javascript实现飞动广告效果的方法
May 25 Javascript
jquery radio的取值_radio的选中_radio的重置方法
Sep 20 Javascript
jQuery实现自动调用和触发某个事件的方法
Nov 18 Javascript
正则验证小数点后面只能有两位数的方法
Feb 28 Javascript
Zepto实现密码的隐藏/显示
Apr 07 Javascript
基于VUE实现的九宫格抽奖功能
Sep 30 Javascript
Node.js中package.json中库的版本号(~和^)
Apr 02 Javascript
JavaScript, select标签元素左右移动功能实现
May 14 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
PHP分页显示制作详细讲解
2006/12/05 PHP
phpmyadmin 常用选项设置详解版
2010/03/07 PHP
限制ckeditor上传图片文件大小的方法
2013/11/15 PHP
php中随机函数mt_rand()与rand()性能对比分析
2014/12/01 PHP
php头像上传预览实例代码
2017/05/02 PHP
Javascript 中的类和闭包
2010/01/08 Javascript
用js实现table单元格高宽调整,兼容合并单元格(兼容IE6、7、8、FF)实例
2013/06/25 Javascript
input:checkbox多选框实现单选效果跟radio一样
2014/06/16 Javascript
AngularJS中的Directive实现延迟加载
2016/01/25 Javascript
JS组件Bootstrap ContextMenu右键菜单使用方法
2016/04/17 Javascript
快速掌握jQuery插件开发
2017/01/19 Javascript
使用typescript开发angular模块并发布npm包
2018/04/19 Javascript
AngularJS日期格式化常见操作实例分析
2018/05/17 Javascript
webpack4 配置 ssr 环境遇到“document is not defined”
2019/10/24 Javascript
使用Python脚本操作MongoDB的教程
2015/04/16 Python
调试Python程序代码的几种方法总结
2015/04/28 Python
Python中单例模式总结
2018/02/20 Python
Python实现自定义函数的5种常见形式分析
2018/06/16 Python
python通过tcp发送xml报文的方法
2018/12/28 Python
python 根据时间来生成唯一的字符串方法
2019/01/14 Python
python3.6中@property装饰器的使用方法示例
2019/08/17 Python
python numpy库np.percentile用法说明
2020/06/08 Python
浅谈TensorFlow中读取图像数据的三种方式
2020/06/30 Python
Python图像处理二值化方法实例汇总
2020/07/24 Python
python中slice参数过长的处理方法及实例
2020/12/15 Python
世界上最大的乐谱选择:Sheet Music Plus
2020/01/18 全球购物
英国最受欢迎的母婴精品品牌:JoJo Maman BéBé
2021/02/17 全球购物
怎样声明接口
2014/09/19 面试题
毕业晚会主持词
2014/03/24 职场文书
工程承包协议书
2014/04/22 职场文书
2014最新开业庆典策划方案(5篇)
2014/09/15 职场文书
党员“四风”方面存在问题及整改措施
2014/09/24 职场文书
2016继续教育培训学习心得体会
2016/01/19 职场文书
2019新员工心得体会
2019/06/25 职场文书
想创业成功,需要掌握这些要点
2019/12/06 职场文书
Golang 实现获取当前函数名称和文件行号等操作
2021/05/08 Golang