资讯专栏INFORMATION COLUMN

细说 jQuery DOM操作篇(二) - DOM 树操作

Anchorer / 1610人阅读

摘要:此时,点击新建的将会触发。设置元素内容的方法则使用上述两种方法,将新内容作为参数传递即可,例如修改上例中的文本内容方法同理。

我们知道通过 $() 函数可以访问文档中的元素,并返回一个 jQuery 对象,并且通过一系列方法,我们可以修改元素的样式和内容,实际上,我们还可以通过该函数做更多的事情,例如添加、删除、复制等操作来改变 DOM 树的结构。

创建元素

我们可以通过 $() 函数来直接创建元素,例如

</>复制代码

  1. $("new");

但仅仅创建了元素,还没有插入到页面中来,接下来介绍插入方法。

插入元素

最基本的四种插入方法如下:

1.insertBefore 指定元素外部,前面
2.insertAfter 指定元素外部,后面
3.prependTo 指定元素内部,前面
4.appendTo 指定元素内部,后面

假设现有元素为一个 div,如下:

</>复制代码

  1. origin

将上例中的 span 插入到 div 内部的前面,可以这样操作:

</>复制代码

  1. $("new").prependTo("div");

结果为:

</>复制代码

  1. neworigin
反向插入元素

我们也可以反向插入元素,对应的方法为:

1.insertBefore - before
2.insertAfter - after
3.prependTo - prepend
4.appendTo - append

对于上例,使用反向插入元素的方法为:

</>复制代码

  1. $("div").prepend("new");

结果是一致的。

移动元素

对于已经存在的元素使用上述的四类方法,则起到移动元素的效果,假设 span 元素已经存在在 div 内部如下:

</>复制代码

  1. neworigin

我们尝试将 span 移至 div 外部的后面,如下:

</>复制代码

  1. $("span").insertAfter("div");

移动后的效果为:

包裹元素

包裹元素即给元素添加一个外层元素,假设现在有两个 span 如下:

</>复制代码

  1. A
  2. B

我们希望给每个 span 都包裹一个 li,从而实现列表化,此时我们可以使用 wrap 方法:

</>复制代码

  1. $("span").wrap("
  2. ");

结果为:

如果我们希望用一个 ul 包裹所有 span 元素,那么可以使用 wrapAll 方法:

</>复制代码

  1. $("span").wrapAll("
      ").wrap("
    • ");
    克隆元素

    克隆元素的方法为 clone,使用起来很简单,但是这里有一点需要注意,克隆元素时,绑定在该元素极其后代元素的事件是否也会被克隆呢,默认情况下是不会的,但是我们可以将其设置为同时克隆。举例如下:

    </>复制代码

    1. clone

    绑定点击事件给 span

    </>复制代码

    1. $("span").click(function() {
    2. alert("hello");//
    3. });

    克隆 span 并插入到 div 内部:

    </>复制代码

    1. $("span").clone().appendTo("div");

    但此时点击新建的 span 并不能触发 alert,因为 clone 方法默认未将绑定的事件克隆,为了达到事件克隆的效果,只需要将参数设置为 true 即可。

    </>复制代码

    1. $("span").clone(true).appendTo("div");

    此时,点击新建的 span 将会触发 alert

    获取、设置元素内容

    假设有 div 如下:

    </>复制代码

    1. content

    我们希望获取 div 元素的内容,可以使用 html 方法。

    </>复制代码

    1. $("div").html()

    返回结果为:"content"

    我们也可以使用 text 方法:

    </>复制代码

    1. $("div").text()

    返回结果为:"content"
    所以很明显,html 方法和 text 方法的区别在于 text 方法只获取纯文本内容,所以 HTML 标签都将被忽略。

    设置元素内容的方法则使用上述两种方法,将新内容作为参数传递即可,例如修改上例中的文本内容:

    </>复制代码

    1. $("div").text("new content")

    html 方法同理。

    参考

    http://book.douban.com/subject/24669823/

    文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

    转载请注明本文地址:https://www.ucloud.cn/yun/87542.html

    相关文章

    • 细说 jQuery 元素(一) - 理解 DOM

      摘要:最强大的特性之一就是简化了对元素的操作。从图中,我们可以看出元素中父元素子元素之间的关系。被封装到对象中的元素会被自动地,隐式地循环遍历。访问从上可知,返回的是对象,但是我们有时也希望直接对元素进行操作。 DOM - Document Object Model,即文档对象模型,它通过对象树来展示 HTML 代码。jQuery 最强大的特性之一就是简化了对 DOM 元素的操作。 DOM...

      everfight 评论0 收藏0
    • 细说 jQuery 元素) - 选择符

      摘要:为了更方便对元素操作,提供了完整的选择符体系,可以分为选择符属性选择符以及自定选择符。选择符几乎支持到规范中的所有选择符。介绍个比较有用的自定义选择符选择符。 为了更方便对 DOM 元素操作,jQuery 提供了完整的选择符体系,可以分为 CSS 选择符、属性选择符以及自定选择符。 CSS 选择符 jQuery 几乎支持 CSS1 到 CSS3 规范中的所有选择符。举例如下: ...

      104828720 评论0 收藏0
    • 细说 jQuery 事件) - 处理简单事件

      摘要:我们可以利用可以对用户发起的事件进行处理,这里以样式转换为例来说明。其他类似的操作事件都可以通过这个方法,将处理事件的程序绑定到同名事件上面。 我们可以利用 jQuery 可以对用户发起的事件进行处理,这里以样式转换为例来说明。 增添样式 基于用户的事件,对特定的 DOM 元素样式进行转换是 jQuery 处理事件中比较常见的情形,举例说明,当用户点击输入框后,会增添 highli...

      ckllj 评论0 收藏0
    • 细说 jQuery DOM操作(一) - 属性操作

      摘要:之前已经知道可以使用和等方法来修改类属性,今天来具体讨论下各种属性的操作。非类属性有时候,我们还需要对一些其他的属性进行操作,例如,,等等。例如单选按钮的属性。 之前已经知道可以使用 addClass 和 removeClass 等方法来修改类属性,今天来具体讨论下各种属性的操作。 非类属性 有时候,我们还需要对一些其他的属性进行操作,例如 href,title,id 等等。这里,...

      ideaa 评论0 收藏0
    • jQuery基础(DOM

      摘要:将匹配元素集合的父级元素删除,保留自身和兄弟元素,如果存在在原来的位置。方法查找指定元素集合中每一个元素的同辈元素。每次回调函数执行时,会传递当前循环次数作为参数从开始计数。 DOM节点的创建 先介绍下需要用到的浏览器提供的一些原生的方法(这里不处理低版本的IE兼容问题)创建流程比较简单,大体如下: 创建节点(常见的:元素、属性和文本) 添加节点的一些属性 加入到文档中流程中涉及的一...

      Harpsichord1207 评论0 收藏0

    发表评论

    0条评论

    Anchorer

    |高级讲师

    TA的文章

    阅读更多
    最新活动
    阅读需要支付1元查看
    <