0

0

如何使用 JavaScript 为每个数据项动态创建独立的列表项(li)

聖光之護

聖光之護

发布时间:2026-02-12 12:05:41

|

560人浏览过

|

来源于php中文网

原创

如何使用 JavaScript 为每个数据项动态创建独立的列表项(li)

本文详解如何在 javascript 中正确创建多个独立的 `

  • ` 元素,避免重复追加同一 dom 节点导致内容合并的问题,并提供简洁、可复用的实现方案。

    在操作 DOM 时,一个常见误区是:试图多次将同一个元素节点(如一个

  • )添加到父容器中
  • 。DOM 规范规定,一个节点在同一时刻只能存在于文档的一个位置;当它被 append() 或 appendChild() 到新父节点时,会自动从原位置移除。因此,你原始代码中反复 ul.append(li) 的行为,实际是不断将同一个

  • 移动到
      末尾,并持续向其内部追加文本——最终所有内容都堆积在单个
    • 内,造成“全部挤在一起”的效果。

      要实现每个字段(如 VIN、Country 等)独占一个

    • ,必须为每一项创建独立的、互不共享的 DOM 元素。以下是两种推荐做法:

      ✅ 方案一:使用 cloneNode(true) 复用模板(适合少量固定字段)

      const result = {
        vin: '4F2YU09161KM33122',
        country: 'United States',
        manufacturer: 'Mazda',
        region: 'North America',
        years: '2001'
      };
      
      const ul = document.getElementById('results');
      const templateLi = document.createElement('li');
      
      // 定义字段映射(更清晰、易维护)
      const fields = [
        { label: 'VIN', key: 'vin' },
        { label: 'Country', key: 'country' },
        { label: 'Manufacturer', key: 'manufacturer' },
        { label: 'Region', key: 'region' },
        { label: 'Years', key: 'years' }
      ];
      
      fields.forEach(({ label, key }) => {
        const li = templateLi.cloneNode(true); // 创建全新 li 实例
        li.textContent = `${label}: ${result[key]}`;
        ul.appendChild(li);
      });
      ? 提示:cloneNode(true) 创建的是深拷贝,包含所有子节点和文本内容;但此处我们仅用它生成空 ,再通过 textContent 赋值,语义清晰且性能良好。

      ✅ 方案二:循环中直接创建新元素(推荐,更直观、更灵活)

      const ul = document.getElementById('results');
      
      ['vin', 'country', 'manufacturer', 'region', 'years'].forEach(key => {
        const li = document.createElement('li');
        const label = key.charAt(0).toUpperCase() + key.slice(1); // 首字母大写(如 'vin' → 'Vin')
        li.textContent = `${label}: ${result[key]}`;
        ul.appendChild(li);
      });

      该方式无需模板节点,逻辑直白,易于扩展(例如增加校验、跳过空值等),也便于后续绑定事件或添加 class。

      飞桨PaddlePaddle
      飞桨PaddlePaddle

      飞桨PaddlePaddle开发者社区与布道,与社区共同进步

      下载

      ⚠️ 注意事项与最佳实践

      • 不要复用已挂载的 DOM 节点:document.createElement() 应在每次循环中调用,或明确使用 cloneNode();
      • 优先使用 textContent 而非 createTextNode() + append():更简洁、防 XSS(自动转义 HTML 字符);
      • 字段顺序建议显式声明:对象属性遍历顺序在 ES2015+ 虽已规范,但显式数组仍是最可靠的方式;
      • 考虑可访问性:如需语义增强,可为每个
      • 添加 role="listitem"(通常非必需,
      • 原生已具备);
      • 错误处理:生产环境建议检查 result[key] !== undefined,避免显示 "undefined"。

      ✅ 最终效果(HTML 输出)

      • VIN: 4F2YU09161KM33122
      • Country: United States
      • Manufacturer: Mazda
      • Region: North America
      • Years: 2001

      掌握这一模式后,你不仅能解决列表渲染问题,还能延伸应用于表格行(

      )、卡片容器(
      )等任何需要批量生成同类型 DOM 元素的场景。核心原则始终如一:每个视觉项 = 一个独立 DOM 节点

      立即学习Java免费学习笔记(深入)”;

  • 热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    堆和栈的区别
    堆和栈的区别

    堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

    410

    2023.07.18

    堆和栈区别
    堆和栈区别

    堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

    586

    2023.08.10

    class在c语言中的意思
    class在c语言中的意思

    在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

    579

    2024.01.03

    python中class的含义
    python中class的含义

    本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

    20

    2025.12.06

    append用法
    append用法

    append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

    347

    2023.10.25

    python中append的用法
    python中append的用法

    在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

    1078

    2023.11.14

    python中append的含义
    python中append的含义

    本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

    178

    2025.09.12

    undefined是什么
    undefined是什么

    undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

    5564

    2023.07.31

    2026春节习俗大全
    2026春节习俗大全

    本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

    189

    2026.02.11

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    React 教程
    React 教程

    共58课时 | 4.9万人学习

    TypeScript 教程
    TypeScript 教程

    共19课时 | 2.9万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 3.3万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号