锋利的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>');
});
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

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