前端学习笔记Web前端之路程序员

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

2017-01-19  本文已影响34人  小夫特

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.查找节点

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 工厂函数 $() 来完成

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

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

//置底操作
$('.moveLast').on('click', function(event) {
   var $tr =  $(this).parents('tr');
   $tr.appendTo('tbody');
//等价与
$('tobdy').append($tr);
});
置底.gif
3.2 prepend 与 prependTo

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

// 置顶操作
$('.moveFirst').on('click', function(event) {
    var $tr =  $(this).parents('tr');
    $tr.prependTo('tbody');
    // 等价于
    $('tbody').prependTo($tr);
});
置顶.gif
3.3 after 与 insertAfter

例子中的向下插入一行用到了这个方法,先创建元素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

例子中的向上插入一行用到了这个方法,先创建元素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>');
});
上一篇 下一篇

猜你喜欢

热点阅读