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
    |
    3月前
    |
    JavaScript 前端开发 UED
    ​基于 vue + element plus + node 实现大文件分片上传,断点续传和秒传的功能!牛哇~
    ​基于 vue + element plus + node 实现大文件分片上传,断点续传和秒传的功能!牛哇~
    |
    6月前
    |
    移动开发 前端开发 Windows
    前端H5怎么简单的实现复制text内容的操作
    前端H5怎么简单的实现复制text内容的操作
    48 0
    前端H5怎么简单的实现复制text内容的操作
    |
    6月前
    |
    JavaScript
    js中添加 删除 替换 插入节点所用的方法
    js中添加 删除 替换 插入节点所用的方法
    53 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
    114 0
    14zTree - 根据参数查找节点
    14zTree - 根据参数查找节点
    41 0
    jq修改页面中的图片地址
    jq修改页面中的图片地址
    149 0
    |
    JavaScript 前端开发
    JavaScript——点击当前节点后删除当前节点
    点击当前节点后删除当前节点
    85 0
    node笔记记录80练习1之3提交表单
    node笔记记录80练习1之3提交表单
    60 0
    node笔记记录80练习1之3提交表单