包装实验室: chapter2/lab.wrapped.set.html
$(‘a’).size()
$(‘a’)[0] 获取第一个
$(‘a’).index($(‘a#a1’)) 获取id=a1的a的下标
添加元素:
Add(字符串|元素|数组)。和 或选择器相比的好处是,可在一条语句中实现: 把粗边框应用到带有alt特性的所有img元素,然后把一定级别的透明度应用到带有alt或title特性的所有img元素:
$(‘img[alt]’).css(‘border’,’solid’).add($(img[title])).css(‘opticpaty’,’30%’)
创建元素
$(元素标签, options): 以前必须先创建标签,再使用 attr完成属性的添加,在1.4中 加入了option参数可以直接完成添加,实例如下
jQuery('<a />', { id: 'foo', href: 'http://google.com', title: 'Become a Googler', rel: 'external', text: 'Go to Google!', css: { fontWeight: 700, color: 'green' }, click: function(){ alert('Foo has been clicked!'); } });
添加脚本:
$('<script/>'): 类似于 <script type="java/script"> </script>
筛选元素
Not(字符串|元素|数组):删除包装集中对应表达式的值,与filter功能相反
Filter(字符串|函数):获取包装集中表达式对应的元素, 如果传递为函数,该函数以当前元素作为this,返回值为true|false
Find(字符串):对包装集和其子集都进行筛选
Contains(字符串):文本中包含字符串
has(字符串|元素): 返回子集中包含参数的元素
获取子集
Slice(begin,end):利用位置
获取第n个元素
Eq(n): $(‘div’).eq(1) 获取第二个段落
判断:
Is(selector):是否包含字符串selector指定的元素,返回true|false
first()
last()
Children()
Parent()
Parents() : 包括直接父元素一直到祖先元素
Next() 下一个兄弟元素
Prev()
NextAll():所有后续兄弟元素的包装集
PrevAll()
Siblings():取得所有同辈节点
Contents():返回原始包装集内容的包装集,这些元素可能包含文本节点(常用于获取iframe元素的内容)
注意:上面兄弟节点不是和选择器同一类型的节点,如$(div).siblings(),可能有img等各种类型。
.closest( selector ) 以定位位置最接近的符合selector的ancestor element(祖先元素)。扩展后的.Closest()支持数组选择器作为参数,这在遍历一个元素的祖先元素时非常有用。如:
< !DOCTYPE html> <html> <head> <style></style> <script src="/scripts/jquery-1.4.js"></script> </head> <body> <ul><li></li><li></li></ul> <script>var close = $("li:first").closest(["ul", "body"]); $.each(close, function(i){ $("li").eq(i).html( this.selector + ": " + this.elem.nodeName ); });</script> </body> </html>
* ul: UL * body: BODY
”nextUntil”, “prevUntil” 和”parentsUntil”,这些方法是用来获取符合条件内的DOM对象。中文你可以理解为“直到”的意思。代码示例:
<ul> <li>Apple</li> <li>Banana</li> <li>Grape</li> <li>Strawberry</li> <li>Pear</li> <li>Peach</li> </ul>
从ul中选择从 <li>Apple</li> 到<li>Pear</li>的元素,如果用1.3的方法: Jquery('ul li').slice(1,4), 而新的方法如下:
jQuery('ul li:contains(Apple)').nextUntil(':contains(Pear)');
虽然上面两者的选取效果是一样的,但若现在我在含有apple的li到含有pear的li中间再添加内容的话,1.32版本的代码就需要修改了,而1.4版本的则可继续使用,也就说1.4版本的代码可用性和语义性增强了。
End() 回退到前一个包装集
Andself():合并最近的两个包装集
复制元素使用.clone()。
删除元素使用.remove()和.detach()。两者的区别在于,前者不保留被删除元素的事件,后者保留,有利于重新插入文档时使用。
清空元素内容(但是不删除该元素)使用.empty()。
swap(字符串|元素) 将包装集中的元素分别包裹元素 ; wrapAll(字符串|元素) 将包装集中的元素作为整体包裹; wrapInner(字符串|元素) 对包装集中元素的内容分别进行包裹 unswap() 去除包装集
toArray() :将Jquery包装集转换为js 的数组
2. 7 移动元素
append()和appendTo() prepend() 和prependTo() before() 和insertBefore() after()和insertAfter()