锋利的jQuery ——jQuery中的DOM操作

Posted hanggedege

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了锋利的jQuery ——jQuery中的DOM操作相关的知识,希望对你有一定的参考价值。

一、DOM的操作分类

1》DOM Core   2》html-DOM   3>CSS-DOM

 

二、jQuery中的DOM操作

技术图片DOM树

①查找节点

1)查找元素节点

技术图片

 

利用jQuery选择器来选中元素,获取元素节点。

 

2)查找属性节点

利用jQuery选择器查找到需要的元素后,用attr()方法来获取它的各种属性的值。

②创建节点

1》创建元素节点

创建节点利用$(html),加入元素用append()还可以连写。

技术图片

 

2》创建文本节点

创建文本节点直接在创建的html元素里面直接添加文本,无论多复杂都可以直接写入。

技术图片

 

 

3》创建属性节点

与创建文本节点类似,直接将属性写入到创建的节点当中。

技术图片

 

 可以利用火狐里面的firebug工具来查看比较。

③ 插入节点

插入节点的方法:

1》append() 和appendTo() 一个是利用jQuery选择器选择元素后插入节点内容。 一个是将节点内容插入到jQuery选择器选到的元素节点中。

技术图片技术图片

 

 

 2》prepend()和prependTo() 向每一个匹配的元素内部插入前置内容,后面是把需要插入的前置内容 插入到选择的元素里。

技术图片

 

3》after()和insertAfter()  在每一个匹配的元素后面插入内容,把要插入的内容插入到选定元素的后面。

技术图片技术图片

 

 4》before()和 inertBefore()在匹配的元素之前插入内容,把要插入的内容插入到元素之前。

技术图片技术图片

 

 ④删除节点

1》remove()   当节点用remove()方法删除后,该节点所包含的所有后代节点将同时被删除,这个方法的返回值是一个指向已被删除的节点的引用,因此可以再使用这些元素,另外remove()方法也可以通过传递参数来选择性的删除元素。

技术图片

 

 

2》detach() 方法,该方法和remove()不一样的是,这个方法删除元素之后,不会把匹配的元素从jQuery对象中删除,因而可以继续使用这些匹配的元素。

技术图片

 

3》empty() 不是删除节点,而是清空节点,清空元素中的所有后代节点。

技术图片

 

 技术图片

 

 ⑤复制节点

clone()

技术图片

复制节点后,被复制的元素不具有有何行为,如果需要新的元素也具有复制功能,可以使用如下代码。

技术图片

 

 在clone()方法中传递了一个参数true,代表复制元素的同时也复制元素中绑定的事件。

⑥替换节点

replaceWith()和replaceAll() replaceWith()是将左右匹配的元素都替换成指定的HTML或者DOM元素,replaceAll()和replaceWith()作用相同,只是颠倒了操作。

 技术图片

 

 ⑦包裹节点

wrap()技术图片

 

wrapAll()将所有匹配的元素用同一个元素来包裹选中的元素。技术图片

 

wrapInner() 将每一个匹配元素的字内容(包括文本节点)用其他结构化的标记包裹起来。技术图片

 

 ⑧属性操作

1》获取属性和设置属性

 attr()方法来获取和设置元素属性,用removeAttr()方法来删除元素属性。

技术图片

还可以设置属性

技术图片

 

 如果需要设置多个属性,用大括号{}括起来,属性和值之间用:号,不同属性中间用,隔开。

技术图片

jQuery中的很多方法都是统一函数实现获取和设置的,如attr(),html(),text(),height(),width(),val()和css()等。

 

 2》删除属性

 removeAttr(),新增的prop()和removeProp()分别用来获取在匹配的元素集中的第一个元素的属性值和为匹配的元素删除设置的属性。

 技术图片

 

 ⑨样式操作

1》获取样式和设置样式

获取样式也可以用attr()来获取和设置。

2》追加样式

用addClass()的方法。

3》移除样式

removeClass()

技术图片

 

 

 可以用空格的方式删除多个class名。当removeClass()里面不带class值的时候等于移除所有的Class。

4》切换样式

toggle()方法主要是控制行为上的重复切换。toggleClass()方法控制样式上的重复切换。

技术图片

 

 

 5》判断是否含有某个样式

hasClass()可以用来判断元素中是否含有某个class,如果有返回true,没有返回false。

⑩设置和获取HTML,文本和值。

1》html()方法

技术图片

 

 

 注意:html()方法可用于XHTML文档,但不能用于XML文档。

2》text() 方法

用来读取或者设置某个元素中的文本内容。

技术图片

 

 

 text()方法支持所有的浏览器,innerText属性不能再firefox浏览器下运行。

3》val()方法

val()无论元素是文本框,下拉列表还是单选框,都可以用val()返回元素的值,如果元素为多选,则返回一个含有所有选择的值的数组。

技术图片

 

 

 技术图片

 

 

 this.defaultValue 就是当前文本框的默认值

技术图片

 

 

 val()案例分析

技术图片

 

 

 val()方法也可以用attr()方法实现同样功能。

技术图片

 

11)遍历节点

 

 ①children()方法y用来获取匹配元素的所有子元素的个数

技术图片

 

 

 children()方法只考虑子元素而不考虑其他的后代元素。

②next()方法

该方法匹配元素后面紧邻的同辈元素。

③pre()方法

用于匹配元素前面紧邻的同辈元素。

④siblings()方法

取得匹配元素前后所有的同辈元素。

⑤closest()方法

用于取得最近的匹配元素。

⑥parent(),parents(),closest()的区别

parent()是获取每个匹配元素的父级元素,parents()是获取匹配元素的祖先元素,closest()获取匹配的最近的父级元素

12)CSS-DOM操作

css()方法获取的高度值与设置有关,可能是auto,也可能是10px;height()获取的高度值是实际高度,不带单位。

offset()方法,作用是获取元素当前视窗的相对偏移,包含两个属性,top和left,只对可见元素有效。

position()方法,获取元素相对于最近的一个position样式属性设置为relative和absolute的祖父节点的相对偏移,也是两个属性top和left。

scrollTop()方法和scrollLeft()方法,分别是获取元素的滚动条距顶端的距离和距左侧的距离。还可以为这两个方法设置参数,控制元素滚动条的滚动位置。

 

以上是关于锋利的jQuery ——jQuery中的DOM操作的主要内容,如果未能解决你的问题,请参考以下文章

jQuery选择器和DOM操作——《锋利的jQuery》(第2版)读书笔记1

《锋利的jQuery》笔记-jQuery部分

jQuery中的事件和动画——《锋利的jQuery》(第2版)读书笔记2

《锋利的jQuery》第4-6章

锋利的jQuery ——jQuery中的事件和动画

《锋利的jQuery》学习笔记