一、节点的创建和删除
1.$("<p>我是新创建的节点</p>")
2.$("<div id='test' class='aaron'>我是文本节点</div>") //直接添加属性
3
empty方法
- 严格地讲,empty()方法并不是删除节点,而是清空节点,它能清空元素中的所有后代节点
- empty不能删除自己本身这个节点
remove方法
- 该节点与该节点所包含的所有后代节点将同时被删除
- 与该节点绑定的事件也销毁
- 提供传递一个筛选的表达式,删除指定合集中的元素
detach()
这个方法不会把匹配的元素从jQuery对象中删除,因而可以在将来再使用这些匹配的元素。与remove()不同的是,所有绑定的事件、附加的数据等都会保留下来。 $("div").detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你append之后,又重新回到了文档流中。就又显示出来了。
二、节点的插入
1.内部插入
- append()向每个匹配的元素内部追加内容
- prepend()向每个匹配的元素内部前置内容
- appendTo()把所有匹配的元素追加到另一个指定元素的集合中
- prependTo()把所有匹配的元素前置到另一个指定的元素集合中
2.外部插入/插入兄弟节点
三、节点的复制与替换
1.clone()
HTML部分 <div></div> JavaScript部分 $("div").on('click', function() {//执行操作}) //clone处理一 $("div").clone() //只克隆了结构,事件丢失 //clone处理二 $("div").clone(true) //结构、事件与数据都克隆
2.replaceWith( newContent ):
用提供的内容替换集合中所有匹配的元素并且返回被删除元素的集合
$("p:eq(1)").replaceWith('<a style="color:red">替换第二段的内容</a>')
3.replaceAll( target ) :
用集合的匹配元素替换每个目标元素
$('<a style="color:red">替换第二段的内容</a>').replaceAll('p:eq(1)')
4.wrap()方法
<p>p元素</p>给p元素增加一个div包裹
$('p').wrap('<div></div>')最后的结构,p元素增加了一个父div的结构
<div> <p>p元素</p> </div>
5.unwarp()方法
<div> <p>p元素</p> </div>但是如果我还要保留内部元素p,这样就意味着需要多做很多处理,步骤相对要麻烦很多,为了更便捷,jQuery提供了unwrap方法很方便的处理了这个问题
$('p').unwrap();找到p元素,然后调用unwrap方法,这样只会删除父辈div元素了
结果:
<p>p元素</p>
6.warpAll()方法
<p>p元素</p> <p>p元素</p>给所有p元素增加一个div包裹
$('p').wrapAll('<div></div>')最后的结构,2个P元素都增加了一个父div的结构
<div> <p>p元素</p> <p>p元素</p> </div>
7.wrapInner( wrappingElement ):
给集合中匹配的元素的内部,增加包裹的HTML结构
<div>p元素</div> <div>p元素</div>给所有元素增加一个p包裹
$('div').wrapInner('<p></p>')最后的结构,匹配的di元素的内部元素被p给包裹了
<div> <p>p元素</p> </div> <div> <p>p元素</p> </div>.wrapInner( function ) :允许我们用一个callback函数做参数,每次遇到匹配元素时,该函数被执行,返回一个DOM元素,jQuery对象,或者HTML片段,用来包住匹配元素的内容
以上面案例为例,
$('div').wrapInner(function() { return '<p></p>'; })以上的写法的结果如下,等同于第一种处理了
<div> <p>p元素</p> </div> <div> <p>p元素</p> </div>
四、遍历
1.children()
作用:返回匹配元素集合中每个元素的所有子元素(仅儿子辈,这里可以理解为就是父亲-儿子的关系)
children()无参数
允许我们通过在DOM树中对这些元素的直接子元素进行搜索,并且构造一个新的匹配元素的jQuery对象
注意:jQuery是一个合集对象,所以通过children是匹配合集中每一给元素的第一级子元素.children()方法选择性地接受同一类型选择器表达式
$("div").children(".selected")
2.find()
.find()和.children()方法是相似的 1.children只查找第一级的子节点 2.find查找范围包括子节点的所有后代节点
3.parent()方法
如果想快速查找合集里面的每一个元素的父元素(这里可以理解为就是父亲-儿子的关系),此时可以用parent()方法
4.parents()
其实也类似find与children的区别,parent只会查找一级,parents则会往上一直查到查找到祖先节点
5.closest()方法
closest()方法接受一个匹配元素的选择器字符串
从元素本身开始,在DOM 树上逐级向上级元素匹配,并返回最先匹配的祖先元素
例如:在div元素中,往上查找所有的li元素,可以这样表达
$("div").closet("li')粗看.parents()和.closest()是有点相似的,都是往上遍历祖辈元素,但是两者还是有区别的,否则就没有存在的意义了
- 起始位置不同:.closest开始于当前元素 .parents开始于父元素
- 遍历的目标不同:.closest要找到指定的目标,.parents遍历到文档根元素,closest向上查找,直到找到一个匹配的就停止查找,parents一直查找到根元素,并将匹配的元素加入集合
- 结果不同:.closest返回的是包含零个或一个元素的jquery对象,parents返回的是包含零个或一个或多个元素的jquery对象
6.next()/prev()
作用:当前节点的下一个上一个节点
7.siblings()
作用:当前节点的兄弟节点
$('.oo').siblings().css('background','red')
8.each()
each() 方法就是一个for循环的迭代器,它会迭代jQuery对象合集中的每一个DOM元素。每次回调函数执行时,会传递当前循环次数作为参数(从0开始计数
所以大体上了解3个重点:
each是一个for循环的包装迭代器 each通过回调的方式处理,并且会有2个固定的实参,索引与元素 each回调方法中的this指向当前迭代的dom元素
$("li").each(function(index, element) {
if (index % 2) {
$(this).css('color','blue')
}
})