锋利的jQuery——读书笔记三 jQuery中的DOM操作

DOM操作的分类

1.DOM Core

DOM Core 不属于Javascript,任何一种支持DOM 的程序设计语言都可以使用它。

Javascript 中的以下方法都是DOM Core 的组成部分

getElementsByTagName()  
getElementById()
getAttribute()
setAttribute()

2.HTML-DOM

提供了一些更简明的记号来描述各种HTML 元素,但是只能用来处理Web文档
eg:

document.froms;   //HTML-DOM 提供了一个forms对象 获取表单对象

element.src     //获取元素src属性

3.CSS-DOM

针对CSS的操作,作用主要是获取和设置 style 对象的各种属性

jQuery中的DOM操作

1.查找节点

  • 查找元素节点,也就是我们之前所说的选择器,通过各种选择器,选出我们需要操作的节点

  • 查找属性节点,通过 jQuery 选择器查找到元素后,可以使用attr() 方法来获取和设置元素,当参数为一个时(需要查询的属性名)为获取元素,当参数为两个时,为设置元素属性值。

eg:

var  pText = $('p').attr('title');  //获取元素的title值
$('p').attr('title','这是设置的title值');  //设置元素的title值
以下我都用一个例子说明

DOM结构:

<table id="table" cellspacing="0" border="l" cellpadding="5" width="500">
    <thead>
        <tr>
          <th>水果</th>
          <th>价格</th>
          <th>Operation     <a class="clearAll" href="#">清空表格</a></th>
        </tr>
    </thead>
    <tbody>
        <tr>
          <td class="Tom">苹果</td>
          <td>18</td>
          <td><a class="del"  href="#">删除</a> | <a class="addUp" href="#">向上添加一行</a> | <a class="addDown" href="#">向下添加一行</a></td>
        </tr>
        <tr>
          <td>橘子</td>
          <td>18</td>
          <td><a class="del"  href="#">删除</a> | <a class="addUp" "  href="#">向上添加一行</a> | <a class="addDown" href="#">向下添加一行</a> | <a class="moveLast" href="#">置底</a></td>
        </tr>
        <tr>
          <td>香蕉</td>
          <td>18</td>
          <td><a class="del"  href="#">删除</a> | <a class="addUp"  href="#">向上添加一行</a> | <a class="addDown" href="#">向下添加一行</a> |  <a class="moveFirst" href="#">置顶</a></td>
        </tr>
        <tr >
          <td><span>菠萝</span></td>
          <td>18</td>
          <td><a class="del"  href="#">删除</a> | <a class="addUp"  href="#">向上添加一行</a> | <a class="addDown" href="#">向下添加一行</a> | <a class="blod" href="#">加粗</a></td>
        </tr>
    </tbody>
</table>
Paste_Image.png

2.创建节点

创建节点是使用jQuery 工厂函数 $() 来完成

  • $(html);
  • 优点: 支持复杂,带文本,属性的html代码
  • eg,创建一个表格的一行
var newTr = $('<tr><td>草莓</td><td>18</td><td>这是添加的一行</td></tr>');

//为了方便易读,可以写成以下
var newTr = $('<tr>'
          +   '<td>草莓</td>'
          +   '<td>18</td>'
          +   '<td>这是添加的一行</td>'
          +   '</tr>');

3.插入节点

3.1 append 与 appendTo
  • **append() **向每个匹配的元素追加内容,在当前操作的元素内部尾部追加内容。$(A).append(B);把B元素追加到A中

  • ** appendTo()** ,$(A).appendTo(B); 把A追加到B中

例子中的置底操作就用了,先在当前点击的元素的父元素中找到 tr 元素,在把当前行插入到tbody 的尾部

//置底操作
$('.moveLast').on('click', function(event) {
   var $tr =  $(this).parents('tr');
   $tr.appendTo('tbody');
//等价与
$('tobdy').append($tr);
});
置底.gif
3.2 prepend 与 prependTo
  • **prepend() **向每个匹配的元素前置内容,在当前操作的元素内部头部追加内容。$(A).prepend(B);把B元素前置到A中

  • ** prependTo()** ,$(A).prependTo(B); 把A前置到B中

例子中的置顶操作就用了,先在当前点击的元素的父元素中找到 tr 元素,在把当前行插入为tbody 的第一个元素

// 置顶操作
$('.moveFirst').on('click', function(event) {
    var $tr =  $(this).parents('tr');
    $tr.prependTo('tbody');
    // 等价于
    $('tbody').prependTo($tr);
});
置顶.gif
3.3 after 与 insertAfter
  • **after() **向每个匹配的元素之后插入内容,在当前元素外部。$(A).insert(B);把B元素插入到A之后

  • ** prependTo()** ,$(A).insertAfter(B); 把A插入到B元素后面

例子中的向下插入一行用到了这个方法,先创建元素newTr ,再插入到当前行之后

//向下添加一行
$('.addDown').on('click', function(event) {
    var newTr = $('<tr><td>草莓</td><td>18</td><td>这是添加的一行</td></tr>');
    var $tr =  $(this).parents('tr');

    newTr.insertAfter($tr);
    //等价于 
    $tr.after(newTr);
});
向下插入行.gif
3.4 before 与 insertBefore
  • **before() **向每个匹配的元素之后插入内容,在当前元素外部。$(A).insert(B);把B元素插入到A之前

  • ** prependTo()** ,$(A).insertAfter(B); 把A插入到B元素前面

例子中的向上插入一行用到了这个方法,先创建元素newTr ,再插入到当前行之前

4. 删除节点

remove() 从DOM中删除所有匹配的元素,可以通过传递参数,选择性删除

detach() ,与romove 相同都是删除元素,detach 删除的元素保存后再次使用时,所有绑定的事件吗、附加的数据都会保留下来。

empty是清空节点

//删除操作
$('.del').on('click', function(event) {
    $(this).parents('tr').remove();
});
//删除全部
$('.clearAll').on('click', function(event) {
    $('tbody').empty();
});
remove 和 empty.gif

5.复制节点

clone(),不带参数的去执行复制操作,复制的元素节点是不带事件的

clone(true), 复制元素的同时复制元素中所绑定的事件

6.包裹节点

wrapAll() ,所有匹配的元素用一个元素来包裹

wrap(),方法将所有的元素进行单独的包裹

wrapInner(),方法将每一个匹配元素的子内容包裹起来

//加粗 元素包裹 当前行就会全部加粗
$('.blod').on('click', function(event) {
    $(this).parents('tr').find('td').wrapInner('<b></b>');
});
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第1章 简介 第2章 DOM节点的创建 2-1 DOM创建节点及节点属性 通过JavaScript可以很方便的获...
    mo默22阅读 4,284评论 0 8
  • DOM创建节点及节点属性 通过JavaScript可以很方便的获取DOM节点,从而进行一系列的DOM操作。但实际上...
    阿r阿r阅读 4,619评论 0 9
  • 一、样式篇 第1章 初识jQuery (1)环境搭建 进入官方网站获取最新的版本 http://jquery.co...
    凛0_0阅读 8,814评论 0 44
  • 学习不是一蹴而就,每天学习一点,蓦然回首,你会发现自己已成功迈出一大步 ~ず(に) 续接: 动词【ない形】+ず(に...
    甘蔗狂人阅读 3,865评论 0 0
  • 16字原则,24字战略,统统围绕8字方针,第一认真第二聪明,学好,了解,懂用,才是真道理。
    踏雪无痕sdf阅读 877评论 0 0