JavaScript修改html文档结构,修改DOM结构 · 廖雪峰 JavaScript Python Git 教程 · 看云

# 修改DOM结构

直接使用浏览器提供的API对DOM结构进行修改,不但代码复杂,而且要针对浏览器写不同的代码。

有了jQuery,我们就专注于操作jQuery对象本身,底层的DOM操作由jQuery完成就可以了,这样一来,修改DOM也大大简化了。

## 添加DOM

要添加新的DOM节点,除了通过jQuery的`html()`这种暴力方法外,还可以用`append()`方法,例如:

```

  • JavaScript
  • Python
  • Swift

```

如何向列表新增一个语言?首先要拿到`<ul>`节点:

```

var ul = $('#test-div>ul');

```

然后,调用`append()`传入HTML片段:

```

ul.append('

Haskell');

```

除了接受字符串,`append()`还可以传入原始的DOM对象,jQuery对象和函数对象:

```

// 创建DOM对象:

var ps = document.createElement('li');

ps.innerHTML = 'Pascal';

// 添加DOM对象:

ul.append(ps);

// 添加jQuery对象:

ul.append($('#scheme'));

// 添加函数对象:

ul.append(function (index, html) {

return '

Language - ' + index + '';

});

```

传入函数时,要求返回一个字符串、DOM对象或者jQuery对象。因为jQuery的`append()`可能作用于一组DOM节点,只有传入函数才能针对每个DOM生成不同的子节点。

`append()`把DOM添加到最后,`prepend()`则把DOM添加到最前。

另外注意,如果要添加的DOM节点已经存在于HTML文档中,它会首先从文档移除,然后再添加,也就是说,用`append()`,你可以移动一个DOM节点。

如果要把新节点插入到指定位置,例如,JavaScript和Python之间,那么,可以先定位到JavaScript,然后用`after()`方法:

```

var js = $('#test-div>ul>li:first-child');

js.after('

Lua');

```

也就是说,同级节点可以用`after()`或者`before()`方法。

## 删除节点

要删除DOM节点,拿到jQuery对象后直接调用`remove()`方法就可以了。如果jQuery对象包含若干DOM节点,实际上可以一次删除多个DOM节点:

```

var li = $('#test-div>ul>li');

li.remove(); // 所有

全被删除

```

## 练习

除了列出的3种语言外,请再添加Pascal、Lua和Ruby,然后按字母顺序排序节点:

```

  • JavaScript
  • Python
  • Swift

```

```

'use strict';

// 测试:

;(function () {

var s = $('#test-div>ul>li').map(function () {

return $(this).text();

}).get().join(',');

if (s === 'JavaScript,Lua,Pascal,Python,Ruby,Swift') {

alert('测试通过!');

} else {

alert('测试失败: ' + s);

}

})();

```

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值