首页 > 代码库 > JQuery中的DOM操作

JQuery中的DOM操作

创建节点

var $newNode = $(“<p>你好</p>”);

插入节点

“$node.append($newNode)”,向每个匹配的元素内部的结尾处追加结尾处。

如,“$("p").append("<b>Hello</b>");”将"<b>Hello</b>"添加到"p"内部的结尾处。

“$newNode.appendTo($node)”,将新元素追加到每个匹配元素内部的结尾处。

 

“$node.prepend($newNode)”,向每个匹配的元素内部的结尾处追加开始处。

如,“$("p").prepend("<b>Hello</b>");”将"<b>Hello</b>"添加到"p"内部的起始处。

“$newNode.prependTo($node)”, 将新元素追加到每个匹配元素内部的开始处。

 

“$node.after($newNode)”,向每个匹配的元素的之后插入内容,是并列兄弟。

如,“$("p").after("<b>Hello</b>");”将"<b>Hello</b>"插入到"p"的后边。它们是兄弟关系。

“$newNode.insertAfter($node)”,将新元素插入到每个匹配元素之后。

 

“$newNode.before($node)”,向每个匹配的元素的之前插入内容。

如,“$("p").before("<b>Hello</b>");”将"<b>Hello</b>"插入到"p"的前面,它们是兄弟关系。

“$node.insertBefore($newNode)”,将新元素插入到每个匹配元素之前。

 注意:如果插入的节点是不是新创建的,插入将变成移动操作。所以,在插入这样的节点之前应该使用clone的节点。

删除节点

从DOM中删除所有匹配的元素。

如,“$("p").remove(".hello");”删除所为class属性值为hello的p元素,和它下面的所有元素。

从DOM中清除所有匹配的元素。

如,“$("p").empty();”清除所有p元素,还有它下面的所有元素。

复制节点

克隆匹配的DOM元素。

如,“$("p").clone();”返回克隆后的副本,但不具有任何行为。

如果要将DOM的事件一起克隆,应该使用“$("p").clone(true);”。

替换节点

将所有匹配的元素都替换为指定的 HTML 或 DOM 元素。

如,$("p").replaceWith("<b>Paragraph. </b>");,将所有p元素,替换为"<b>Paragraph. </b>"。

与replaceWith相返:$("<b>Paragraph. </b>").replaceAll("p");。

包裹节点

wrap():将指定节点用其他标记包裹起来。该方法对于需要在文档中插入额外的结构化标记非常有用, 而且不会破坏原始文档的语义。

如,“$("p").wrap("<div class=‘wrap‘></div>");”。每个p元素被包裹到<div>中。

wrapAll():将所有匹配的元素用一个元素来包裹。而wrap()方法是将所有的元素进行单独包裹。

如,“$("p").wrapAll("<div></div>");”,将所有p元素包裹到<div>中。

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

如,“$("p").wrapInner("<b></b>");”, <b>被每一个p元素包裹。

属性设置

attr():获取属性和设置属性。当为该方法传递一个参数时,即为某元素的获取指定属性。

如,“$("img").attr("src");”,获取img元素的src属性值。

当为该方法传递两个参数时,即为某元素设置指定属性的值。

如,“$("img").attr("src","test.jpg");”,设置img元素的src属性值为test.jsp。

jQuery 中有很多方法都是一个函数实现获取和设置。

如:attr(),html(),text(),val(),height(),width(),css()等。

removeAttr():删除指定元素的指定属性。

样式操作

可以通过“attr()”设置或获取css样式。

追加样式:addClass()

如,“$("p").addClass("selected");”,向所有P元素中追加“selected”样式。

移除样式:removeClass() --- 从匹配的元素中删除全部或指定的class。

如,“$("p").removeClass("selected");”,删除所有P元素中的“selected”。

切换样式:toggleClass() --- 控制样式上的重复切换。如果类名存在则删除它,如果类名不存在则添加它。

如,“$("p").toggleClass("selected");”,所有的P元素中,如果存在“selected”样式就删除“selected”样式,否则就添加“selected”样式。

判断样式:hasClass() --- 判断元素中是否含有某个 class,有返回 true; 否则返回 false。

如,“$(this).hasClass("protected")”,判断当前节点是否有“protected”样式。

设置或获取HTML、文本和值

读取和设置某个元素中的 HTML 内容: html(),该方法可以用于 XHTML,但不能用于 XML 文档。

读取和设置某个元素中的文本内容:text(),该方法既可以用于 XHTML 也可以用于 XML 文档。

读取和设置某个元素中的值:val(),该方法类似 JavaScript 中的 value 属性。对于文本框,下拉列表框,单选框该方法可返回元素的值(多选框只能返回第一个值)。如果为多选下拉列表框,则返回一个包含所有选择值的数组。

常用遍历节点的方法

取得匹配元素的所有子元素组成的集合:children()。该方法只考虑第一层子元素而不考虑任何后代元素。

取得匹配元素后面紧邻的兄弟元素的集合(但集合中只有一个元素):next()。

取得匹配元素前面紧邻的兄弟元素的集合(但集合中只有一个元素):prev()。

取得匹配元素前后所有的兄弟元素: siblings()。

CSS-DOM操作

获取和设置元素的样式属性:css()。

获取和设置元素透明度:opacity()属性。

获取和设置元素高度,宽度:height(),width()。在设置值时,若只传递数字,则默认单位是px。如需要使用其他单位则需传递一个字符串,

例如 “$(“p:first”).height(“2em”)”;

获取元素在当前视窗中的相对位移:offset()。它返回的对象包含了两个属性:top,left。该方法只对可见元素有效。

JQuery中的DOM操作