jq修改节点内容6

简介: jq修改节点内容6

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


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


添加DOM


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


<div id="test-div">
    <ul>
        <li><span>JavaScript</span></li>
        <li><span>Python</span></li>
        <li><span>Swift</span></li>
    </ul>
</div>




如何向列表新增一个语言?首先要拿到

    节点:


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


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


ul.append('<li><span>Haskell</span></li>');


除了接受字符串,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('<li><span>Lua</span></li>');


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


删除节点


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


var li = $('#test-div>ul>li');
li.remove(); // 所有全被删除


练习


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


<!-- HTML结构 -->
<div id="test-div">
    <ul>
        <li><span>JavaScript</span></li>
        <li><span>Python</span></li>
        <li><span>Swift</span></li>
    </ul>
</div>

  • 'use strict';


    // 测试:
    ;(function () {
        var s = $('#test-div>ul>li').map(function () {
            return $(this).text();
        }).get().join(',');
        if (s === 'JavaScript,Lua,Pascal,Python,Ruby,Swift') {
            console.log('测试通过!');
        } else {
            console.log('测试失败: ' + s);
        }
    })();
    相关文章
    |
    6月前
    |
    JavaScript
    js添加 删除 替换 插入节点所用的方法
    js添加 删除 替换 插入节点所用的方法
    35 0
    |
    JavaScript 前端开发
    js中访问节点和创建节点的方法都有什么?
    js中访问节点和创建节点的方法都有什么?
    63 0
    |
    5月前
    |
    JavaScript 前端开发
    JS中访问节点和创建节点的方法都有什么?
    JS中访问节点和创建节点的方法都有什么?
    31 0
    |
    6月前
    |
    JavaScript
    js中添加 删除 替换 插入节点所用的方法
    js中添加 删除 替换 插入节点所用的方法
    56 0
    |
    11月前
    |
    JavaScript
    Vue + Element UI 实现复制当前行数据功能(复制到新增页面组件值不能更新等问题解决)
    # 1、需求 使用Vue + Element UI 实现在列表的操作栏新增一个复制按钮,复制当前行的数据可以打开新增弹窗后亦可以跳转到新增页面,本文实现为跳转到新增页面。 # 2、实现 ## 1)列表页 index.vue ```html <el-table> <!-- 其他列 --> <el-table-column label="操作" width="150"> <template slot-scope="scope"> <el-button icon="el-icon-copy-document" title="复制" @click="toCopyNew(scope
    118 0
    jq修改页面中的图片地址
    jq修改页面中的图片地址
    150 0
    |
    JavaScript 前端开发
    JavaScript——点击当前节点后删除当前节点
    点击当前节点后删除当前节点
    86 0
    |
    JavaScript
    js基础笔记学习214元素得属性和节点1方式1
    js基础笔记学习214元素得属性和节点1方式1
    75 0
    js基础笔记学习214元素得属性和节点1方式1
    |
    JavaScript 前端开发
    带你彻底学会JS DOM技术之删除,复制,替换元素
    参数obj表示被复制的元素,而参数bool是一个布尔值,取值如下。 1或true:表示复制元素本身以及复制该元素下的所有子元素。 0或false:表示仅仅复制元素本身,不复制该元素下的子元素。
    313 0
    带你彻底学会JS DOM技术之删除,复制,替换元素