jQuery 第二课 操作包装集元素代码


Posted in Javascript onMarch 14, 2010

例如:

<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>jQuery Wrapper</title> 
<script type="text/javascript" src="jquery-1.3.2.js"></script> 
<script type="text/javascript"> 
$(function() { 
$("<p>I am a red line.</p>").css("color", "Red").appendTo("#foo"); 
}); 
</script> 
</head> 
<body> 
<div id="foo"> 
</div> 
</body> 
</html>

$创造了一个p元素的包装元素,这个包装元素和用上文提到的选择符选到的元素是一样的。同样也可以调用jQuery的一些方法,最后用appendTo(以后介绍)把这个元素移动到div里。最终结果是:

jQuery 第二课 操作包装集元素代码

下面介绍对包装集操作的函数。

1. html(),html(text). 第一个函数返回包装集第一个元素内部的html,第二个函数将包装集中的所有元素的内部html设置为text。

2.size()。返回包装集包含的元素。

3.get(),get(n)。第一个函数将包装集合内的HTML元素以javascript数组的形式返回,第二个元素返回第n个HTML元素。

4.index(elem). 返回传入的HTML元素elem在包装集中的位置。如果不在包装集中,则返回-1。

5.add(s),add(elem),add(array). add函数用于向包装集中添加元素。如果是选择器,则添加所有被选中的元素,如果是HTML片段,则根据此片段创建HTML元素并添加此元素;如果是HTML元素或者HTML元素的数组,则直接添加。

6. not(expression),filter(expression). 这两个函数是用来筛选包装集的元素的。expression可以是一个字符串(选择符),或者是html元素或者元素数组。not函数除去符合选择符的元素或者包含在数组中的元素。filter则相反,留下符合选择符的元素或者包含在数组中的元素。

7.slice(begin,end) 这个函数返回的是一个新建的包装集,内容是原包装集从第begin到第end个元素。end省略则表示最大长度。

先来看几个例子。

<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>jQuery Wrapper</title> 
<script type="text/javascript" src="jquery-1.3.2.js"></script> 
<script type="text/javascript"> 
$(function() { 
$('span').html($('li').size()); 
$('li').not('li:first').add('p:first').css('color', 'Red'); 
$('li').get(0).innerHTML = "First Special Item"; 
$('p:last').html($('li').html()); 
}); 
</script> 
</head> 
<body> 
<ul> 
<li>First Item</li> 
<li>Second Item</li> 
<li>Third Item</li> 
<li>Forth Item</li> 
<li>Fifth Item</li> 
</ul> 
<p>I am a lonely p.</p> 
<p>The UL has <span></span> elements.</p> 
<span>Hello jQuery.</span> 
<p></p> 
</body> 
</html>

第一行演示了html和size的用法。按上面的介绍,两个span中的内容都应该会变成5. 第二行演示了not和add的一个用法。最终后四个li和第一个p会变成红色。第三行演示了get的用法,一旦调用get之后,返回值就不是包装元素而是HTML元素,因此可以使用HTML DOM提供的方法设置innerHTML。最后一行还是演示html()的用法,要注意html()返回的是第一个元素的内部内容,但是html(text)会把所有元素的内容都设置成text。 最终的结果如下:

jQuery 第二课 操作包装集元素代码

9. 这是一大类非常有用的函数,可以根据位置关系筛选元素。

children() 返回包装集内元素的子元素(儿子元素,往下多层的不算)
contents() 返回包装集的内容的包装集,可能有文本节点(这个包装集有些特殊,下面介绍)
next() 包装集元素中不重复的下一个元素。
nextAll() 包装集元素中所有的下一个元素。
parent() 包装集中元素不重复的父元素的包装集
parents() 同上,但是一直向上追溯到文档根元素(不包括根元素)
prev() 类似next(),所有不重复的前一个元素
prevAll() 类型nextAll(),所有前一个元素
siblings() 包装集中所有不重复的兄弟元素。

先看前两个函数的区别,HTML代码还是用上一个例子的,js脚本如下:

$(function() { 
var ul = $('ul:first'); 
$('p span').html(ul.children().size()); 
var content = ul.contents(); 
alert(content.size()); 
});

children()返回的包装集的数量是6,说明最后一个嵌套的<ul>仅算作一个元素。但是contents()返回的包装集的数量多达13。利用调试器查看一下它的内容:
jQuery 第二课 操作包装集元素代码
它和children的区别就是包含了大量的Text节点,包括仅仅是一个空行的文本节点。

再看next和nextAll方法,仍然使用上面的HTML的代码,js脚步如下:

$(function() { 
$('span:last').html($('ul').next().html()); 
$('p:last').html($('ul').nextAll().size()); 
});ul的下个元素应该是I am a lonely p.所有 下个元素共有4个。故结果为:

jQuery 第二课 操作包装集元素代码 
其他函数使用类似,不再举例。
10.find
find方法和filter方法很容易混淆,同样也是传入一个选择符筛选包装集中的元素。不过find筛选的是包装集内元素的子元素,filter是筛选的包装集内的元素。下面会举一个例子。
11 clone
clone方法返回一个包装集的副本。
例子:
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>jQuery Wrapper</title> 
<script type="text/javascript" src="jquery-1.3.2.js"></script> 
<script type="text/javascript"> 
$(function() { 
$('body').children().filter('p:first').css('color', 'Red').appendTo('#container'); 
$('body').children().find('p').css('color', 'Green').appendTo('#container'); 
$('p:last').clone().css('color', 'Red').appendTo('body'); 
}); 
</script> 
</head> 
<body> 
<p>I am a lonely p.</p> 
<div>The UL has <p>Inner P</p> elements.</div> 
<p>Hello jQuery.</p> 
<div id='container'></div> 
</body> 
</html>

这是一个比较有意思的例子。第一行筛选出第一个p并且设为红色,再移动到最后的一个div中。第二行筛选出包含在包装集中的p,设为绿色,移动到最后一个div中,注意这里,此时这句筛选到的p有两个,一个是Inner P,还有一个是被第一句移动到最后的div中的 I am a lonely p.再把这两个元素添加到最后的div中,由于InnerP本身就在这个div中,所以相当于没有移动。最后,把最后一个p复制一份,设置为红色,添加到body最后。因此,最终的页面和色彩如下:
jQuery 第二课 操作包装集元素代码 
最后介绍连缀链的管理。所谓连缀链,上面的例子也有体现,就是每调用一个jQuery方法它都返回一个包装集,这个包装集作为下一个方法的调用者,构成一个链。在这个过程中有可能会产生新的包装集(比如调用clone())方法。在一个连缀链中,如果调用end方法,则返回上一个包装集,如果调用andSelf方法则把当前和上一个包装集合并成一个包装集并返回。可以想到,jQuery内部把这些连缀的包装集存在一个堆栈中。下面的简单例子展示上述原理:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title>jQuery Wrapper</title> 
<script type="text/javascript" src="jquery-1.3.2.js"></script> 
<script type="text/javascript"> 
$(function() { 
$('div:eq(0)').find('p:lt(2)').css('color', 'red'); 
$('div:eq(1)').find('p:lt(2)').end().css('color', 'blue'); 
$('div:eq(2)').find('p:last').prev().andSelf().css('color', 'Green'); 
}); 
</script> 
</head> 
<body> 
<div> 
<p>div1 p1</p> 
<p>div1 p2</p> 
<p>div1 p3</p> 
</div> 
<div> 
<p>div2 p1</p> 
<p>div2 p2</p> 
<p>div2 p3</p> 
</div> 
<div> 
<p>div3 p1</p> 
<p>div3 p2</p> 
<p>div3 p3</p> 
</div> 
</body> 
</html>

jQuery 第二课 操作包装集元素代码
Javascript 相关文章推荐
location.href 在IE6中不跳转的解决方法与推荐使用代码
Jul 08 Javascript
js获得指定控件输入光标的坐标兼容IE,Chrome,火狐等多种主流浏览器
May 21 Javascript
基于JS实现EOS隐藏错误提示层代码
Apr 25 Javascript
JS实用技巧小结(屏蔽错误、div滚动条设置、背景图片位置等)
Jun 16 Javascript
jquery+ajax+text文本框实现智能提示完整实例
Jul 09 Javascript
使用selenium抓取淘宝的商品信息实例
Feb 06 Javascript
vue translate peoject实现在线翻译功能【新手必看】
Jun 07 Javascript
javascript中的event loop事件循环详解
Dec 14 Javascript
JavaScript实现shuffle数组洗牌操作示例
Jan 03 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
Feb 18 Javascript
JS使用正则表达式判断输入框失去焦点事件
Oct 16 Javascript
JavaScript原型链中函数和对象的理解
Jun 16 Javascript
jQuery入门第一课 jQuery选择符
Mar 14 #Javascript
使用JavaScript switch case 另类写法
Mar 14 #Javascript
两个JavaScript jsFiddle JSBin在线调试器
Mar 14 #Javascript
input的focus方法使用
Mar 13 #Javascript
JavaScript prototype对象的属性说明
Mar 13 #Javascript
clientX,pageX,offsetX,x,layerX,screenX,offsetLeft区别分析
Mar 12 #Javascript
JS在IE和FireFox之间常用函数的区别小结
Mar 12 #Javascript
You might like
帅气的琦玉老师
2020/03/02 日漫
批量去除PHP文件中bom的PHP代码
2012/03/13 PHP
Javascript公共脚本库系列(一): 弹出层脚本
2011/02/24 Javascript
JavaScript中的16进制字符(改进)
2011/11/21 Javascript
javascript中interval与setTimeOut的区别示例介绍
2014/03/14 Javascript
Area 区域实现post提交数据的js写法
2014/04/22 Javascript
node.js中的fs.linkSync方法使用说明
2014/12/15 Javascript
jQuery插件slicebox实现3D动画图片轮播切换特效
2015/04/12 Javascript
JavaScript中字符串与Unicode编码互相转换的实现方法
2015/12/18 Javascript
详解AngularJS 模态对话框
2016/04/07 Javascript
利用jQuery来动态为属性添加或者删除属性的简单方法
2016/12/02 Javascript
js实现刷新页面后回到记录时滚动条的位置【两种方案可选】
2016/12/12 Javascript
Web前端框架bootstrap实战【第一次接触使用】
2016/12/28 Javascript
JavaScript的for循环中嵌套一个点击事件的问题解决
2017/03/03 Javascript
jQuery插件FusionCharts绘制ScrollColumn2D图效果示例【附demo源码下载】
2017/03/22 jQuery
JS实现留言板功能
2017/06/17 Javascript
vue使用drag与drop实现拖拽的示例代码
2017/09/07 Javascript
JS实现的全排列组合算法示例
2017/10/09 Javascript
vue.js开发实现全局调用的MessageBox组件实例代码
2017/11/22 Javascript
详解Vue微信授权登录前后端分离较为优雅的解决方案
2018/06/29 Javascript
JS加密插件CryptoJS实现的DES加密示例
2018/08/16 Javascript
Vue.set()动态的新增与修改数据,触发视图更新的方法
2018/09/15 Javascript
详解Vue的组件中data选项为什么必须是函数
2020/08/17 Javascript
Vite和Vue CLI的优劣
2021/01/30 Vue.js
[02:05]2014DOTA2西雅图国际邀请赛 BBC第二天小组赛总结
2014/07/11 DOTA
Python中处理字符串之islower()方法的使用简介
2015/05/19 Python
深入理解python函数递归和生成器
2016/06/06 Python
浅谈python中的变量默认是什么类型
2016/09/11 Python
深入浅析Python中list的复制及深拷贝与浅拷贝
2018/09/03 Python
python 实现提取某个索引中某个时间段的数据方法
2019/02/01 Python
Python转换字典成为对象,可以用&quot;.&quot;方式访问对象属性实例
2020/05/11 Python
python collections模块的使用
2020/10/16 Python
详解python中的三种命令行模块(sys.argv,argparse,click)
2020/12/15 Python
土耳其时尚购物网站:Morhipo
2017/09/04 全球购物
应届毕业生自荐书
2014/06/18 职场文书
基石观后感
2015/06/12 职场文书