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);
        }
    })();
    相关文章
    |
    2月前
    |
    运维 算法 数据挖掘
    【故障定位系列】基于DeepSeek的故障定位大揭秘
    传统故障定位依赖专家经验与固定算法,难以应对复杂场景。引入DeepSeek大模型后,可凭借其强大推理与自适应能力,实现智能故障定位。通过“大模型+Agent”协同架构,大模型负责决策,Agent执行数据分析,既降低Token消耗,又保留智能化分析优势。未来,随着大模型理解与推理能力提升,故障定位将更高效、精准。
    |
    7月前
    |
    人工智能 编解码 芯片
    告别低效沟通|让技术提问不再头疼-这套高效AI提问模板来帮你
    不会向ai提问,不知道怎么提问的 可以看看
    20722 1
    告别低效沟通|让技术提问不再头疼-这套高效AI提问模板来帮你
    |
    7月前
    |
    机器学习/深度学习 算法 搜索推荐
    数据不忽悠:如何用大数据预测未来?
    数据不忽悠:如何用大数据预测未来?
    391 12
    |
    6月前
    |
    API 开发工具 开发者
    HarmonyOS NEXT实战:拨打电话
    本课程介绍如何在HarmonyOS SDK中使用Telephony Kit实现拨打电话功能。通过CallPhoneDemoPage示例,讲解如何输入电话号码并调用makeCall接口拨号,涉及call模块的使用及设备通话能力检测。
    7868 0
    |
    Web App开发 编解码 资源调度
    在阿里云直播解决方案中,当使用ARTC协议观看直播并进行清晰度切换时出现画面卡顿或马赛克现象,可能存在以下几种原因
    【6月更文挑战第30天】阿里云直播中,ARTC协议下清晰度切换出现卡顿或马赛克可能由网络带宽、缓冲策略、转码效率、播放器解码、协议特点及服务器资源调度引起。解决措施包括优化网络、智能切换算法、播放器与服务器优化。通过监控和日志分析定位问题,参照官方最佳实践进行优化。
    616 1
    |
    9月前
    |
    人工智能 监控 算法
    卷不过AI就驯服它!AI训练师速成攻略
    这是一篇关于AI训练师职业的全面指南。文章从“驯服AI”的理念出发,将AI训练师比作“幼儿园老师”,详细描述了该职业的工作内容、入行技能要求、成长路径及工作日常。新手可以从基础的数据标注做起,逐步学习Python、数学知识和工具使用,通过三年计划实现职业进阶。文中还分享了摸鱼技巧、崩溃与高光时刻,以及避坑建议和未来转型方向。无论是在电商公司给商品打标签,还是训练医疗AI辅助诊断,这个职业都充满挑战与机遇。最后鼓励大家主动拥抱变化,把AI变成自己的左膀右臂,而非竞争对手。
    1849 1
    |
    11月前
    |
    人工智能 供应链 安全
    阿里云 Confidential AI 最佳实践
    本次分享的主题是阿里云 Confidential AI 最佳实践,由阿里云飞天实验室操作系统安全团队工程师张佳分享。主要分为三个部分: 1. Confidential AI 技术背景与挑战 2. Confidential AI 技术架构与应用场景 3. Confidential AI 技术实践与未来展望
    426 2
    |
    人工智能
    阿里国际站推出AI极简出海计划
    【2月更文挑战第19天】阿里国际站推出AI极简出海计划
    403 1
    阿里国际站推出AI极简出海计划
    |
    存储 算法 Java
    【数据结构】树结构(B树、23树、B+树)
    【数据结构】树结构(B树、23树、B+树)
    340 0
    【数据结构】树结构(B树、23树、B+树)