JavaScript 动态创建元素并添加唯一ID

javascript 动态创建元素并添加唯一id

本文介绍了如何使用 JavaScript 在循环中动态创建 div 元素,并为每个元素赋予唯一的 ID。通过利用循环的索引,可以方便地生成递增的 ID,从而实现对每个动态创建元素的精细控制。同时,本文也展示了如何更有效地组织数据,避免冗余的变量声明,使代码更简洁易懂。

前端开发中,经常需要在 JavaScript 中动态创建 HTML 元素。当需要对这些动态创建的元素进行单独操作时,为每个元素赋予唯一的 ID 就显得尤为重要。本文将详细介绍如何使用 forEach 循环动态创建 div 元素,并为每个元素添加唯一的 ID 属性。

使用 forEach 循环动态创建元素并添加 ID

假设我们有一个包含书籍信息的数组 myLibrary,我们需要根据数组中的每个元素创建一个 div 元素,并将其添加到 booksContainer 容器中。同时,我们需要为每个 div 元素设置一个唯一的 ID,例如 booksDisplay1、booksDisplay2 等。

以下是实现该功能的代码示例:

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

const booksContainer = document.getElementById('booksContainer');const myLibrary = [  {    imageUrl: '',    title: 'Title: Armageddon: The Battle for Germany, 1944-1945',    author: 'Author: Max Hastings',    pages: 'Pages: 672'  },  {    imageUrl: '',    title: 'book 2',    author: '',    pages: ''  },  {    imageUrl: '',    title: 'book 3',    author: '',    pages: ''  },  {    imageUrl: '',    title: 'book 4',    author: '',    pages: ''  }];myLibrary.forEach((book, index) => {  let booksDisplay = document.createElement('div');  booksDisplay.setAttribute('class', 'booksDisplay');  booksDisplay.setAttribute('id', `booksDisplay${index + 1}`);  let booksDisplayText = document.createTextNode(`${book.title}: ${book.author}: ${book.pages}`);  booksDisplay.appendChild(booksDisplayText);  booksContainer.appendChild(booksDisplay);});

代码解释:

获取容器元素: 首先,使用 document.getElementById(‘booksContainer’) 获取 ID 为 booksContainer 的元素,该元素将作为所有动态创建的 div 元素的父容器。

定义书籍信息数组: myLibrary 数组包含了书籍的信息,每个元素都是一个对象,包含 imageUrl、title、author 和 pages 属性。

使用 forEach 循环遍历数组: myLibrary.forEach((book, index) => { … }); 使用 forEach 方法遍历 myLibrary 数组,对每个书籍对象执行回调函数。回调函数接收两个参数:book 表示当前书籍对象,index 表示当前元素的索引。

创建 div 元素: 在回调函数中,使用 document.createElement(‘div’) 创建一个新的 div 元素,并将其赋值给 booksDisplay 变量。

设置 class 属性: 使用 booksDisplay.setAttribute(‘class’, ‘booksDisplay’) 为 div 元素设置 class 属性,值为 booksDisplay。

设置 id 属性: 使用 booksDisplay.setAttribute(‘id’, booksDisplay${index + 1}`)为div元素设置id属性。这里使用了模板字符串,将index + 1的值插入到字符串中,从而生成唯一的 ID。注意,索引从 0 开始,因此需要index + 1` 来生成从 1 开始的 ID。

创建文本节点并添加到 div 元素: 使用 document.createTextNode(${book.title}: ${book.author}: ${book.pages}`)创建一个包含书籍信息的文本节点,并使用booksDisplay.appendChild(booksDisplayText)将其添加到div` 元素中。

将 div 元素添加到容器元素: 使用 booksContainer.appendChild(booksDisplay) 将创建好的 div 元素添加到 booksContainer 容器中。

注意事项

确保 booksContainer 元素在 HTML 中存在,并且具有正确的 ID。ID 的命名规则应遵循 HTML 规范,避免使用特殊字符和空格。如果需要动态更新书籍信息,可以使用 JavaScript 找到对应的 div 元素,并修改其内容。

总结

通过使用 forEach 循环和 setAttribute 方法,可以方便地动态创建 div 元素,并为每个元素添加唯一的 ID。这种方法在需要对动态创建的元素进行单独操作时非常有用。同时,合理组织数据结构可以使代码更简洁易懂。

以上就是JavaScript 动态创建元素并添加唯一ID的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1579681.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 20:49:15
下一篇 2025年12月22日 20:49:27

相关推荐

  • CSS 预处理器

    CSS 预处理器是什么?一般来说,它们基于 CSS 扩展了一套属于自己的 DSL(Domain Specific Language),来解决我们书写 CSS 时难以解决的问题: 语法不够强大,比如无法嵌套书写导致模块化开发中需要书写很多重复的选择器;没有变量和合理的样式复用机制,使得逻辑上相关的属性…

    好文分享 2025年12月24日
    000
  • css需要什么环境

    在编写代码之前得有个编写的环境才行,css的代码编写也是如此,本篇文章将和大家讲述css的编写环境,有需要的朋友可以了解一下。 实际上,你只需要一个文本编辑器(或IDE)+浏览器。 文本编辑器推荐sublime text或者atom。 IDE推荐Dreamweaver或webstorm。当然还有其他…

    2025年12月24日
    000
  • 学html css看什么书?

    我们在学习html+css的过程中我们可以看看一些大牛写的书籍,会受益匪浅。下面我将介绍几本关于css以及html的书籍,感兴趣的朋友可以了解一下。 1、《CSS那些事儿》 本书专注于CSS技巧实例的讲解,由浅入深地分析了CSS样式在布局时所需要理解的原理。绕开随处可见的基础知识、网络中能随意搜索到…

    2025年12月24日
    000
  • css全称是什么意思

    css的英文全称为cascading style sheets。几个单词拆开翻译,cascading有大量的意思,style有风格样式的意思,sheets有表格的意思,整合在一起翻译为中文意思为层叠样式表。 层叠样式表是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一…

    2025年12月24日
    000
  • css怎么嵌入到html中?

    Some red text 优点: 1、如果您想测试和预览更改,则非常有用。 2、对快速修复很有用。 3、降低HTTP请求。 缺点: 内联CSS必须应用于每个元素。 嵌入式样式 特点: 1)、被放置在样式标签 编写的网页的头部部分中。 2)、编写的样式将仅用于您使用它的网页。 3)、嵌入样式也称为“…

    2025年12月24日
    000
  • 怎么用div布局?

    div是层叠样式表中的定位技术,全称division,即为划分。有时可以称其为图层。div在编程中又叫做整除,即只得商的整数。 div元素是用来为html(标准通用标记语言下的一个应用)文档内大块(block-level)的内容提供结构和背景的元素。 是一个块级元素。这意味着它的内容自动地开始一个新…

    2025年12月24日
    000
  • css是什么含义

    css指的是层叠样式表,是一种用来表现HTML或XML等文件样式的计算机语言,是描述标记语言页面格式的标准。CSS使开发人员能够分离内容和可视元素,以实现更好的页面控制和灵活性。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。 你在学习前端的过程中有没有了解过CSS…

    2025年12月24日
    000
  • CSS实现菜单按钮动画的代码示例

    本篇文章给大家带来的内容是关于css实现菜单按钮动画的代码示例,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 要写一个下拉菜单点击按钮 菜单入口就是是点击一个图标按钮 之前都是随便用个图片代替 今天突然想用CSS写个效果 主要参考澎湃移动端右上角的按钮 效果: 立即学习“前端免费学…

    2025年12月24日
    000
  • html中表格tr的td单元格怎么设置宽度属性

    table的宽度是自适应的,而且部分TD是固定宽度。原则上应该讲table的宽度设置成一个固定的值,而不应该设置成一个根据屏幕变化的值。现在来看下如何设置表格td单元格的宽度。 例1:Table的宽度为600px,Table的td所有宽度总和不到600px,浏览器会自动按照td的宽度的比例算出宽度 …

    2025年12月24日
    000
  • CSS 如何进行单一div的正多边形变换

    本文是纯粹利用css,让“单一个”div,从正三角形变换为正八边形(单一div最多只能做到正八边形),最后再搭配动画的效果,变成正多边形的变换动画,也由于正多边形需要用到不少的三角函数计算,为了方便起见,这里将正多边形的边统一都设为100px。 正三角形 正三角形不需要用到伪元素,只需要设定p本身的…

    2025年12月24日 好文分享
    000
  • 清除浮动和闭合浮动的介绍

    本篇文章给大家带来的内容是关于清除浮动和闭合浮动的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 为什么要清除浮动 子元素 float:left; 脱离文档流,会造成父元素塌陷(撑不起来) 父元素 靠子元素撑起来 清除浮动  clear:both 清除浮动 // 伪元素 :af…

    好文分享 2025年12月24日
    000
  • 选择器(picker)插件的实现方法介绍(代码)

    本篇文章给大家带来的内容是关于选择器(picker)插件的实现方法介绍(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一个正常的选择器插件是非常细致的,一步一步来描述就是。手指滑动内容跟随手指滚动,当内容到底或触顶的时候就不能在滚动并且内容要一直保持在正确的位置上。 第一步…

    2025年12月24日
    000
  • CSS实现基于用户滚动应用(代码)

    本篇文章给大家带来的内容是关于css实现基于用户滚动应用(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 通过将当前滚动偏移映射到html元素上的属性,我们可以根据当前滚动位置设置页面上的元素样式。我们可以使用它来构建一个浮动导航组件。 这是我们将使用的HTML, 当我们向下…

    好文分享 2025年12月24日
    000
  • CSS的工作过程介绍(图文)

    本篇文章给大家带来的内容是关于css的工作过程介绍(图文),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 在平时的工作中,可能都是再用一些框架或者是简单的CSS来修饰我们的HTML页面,那么仔细想想一个资深的前端从业者,是否需要知道他的工作原理和过程呢,技术这种东西,当然是我们了解…

    2025年12月24日
    000
  • pop()方法怎么用

    javascript pop()方法可用于删除javascript数组中的最后一个元素并且返回数该删除的元素。 javascript pop()方法 作用:pop() 方法用于删除并返回数组的最后一个元素。 基本语法: arrayObject.pop() 注:pop() 方法会改变数组的长度。 说明…

    2025年12月24日
    000
  • css隐藏移动端滚动条并平滑滚动(代码示例)

    本篇文章给大家带来的内容是关于css隐藏移动端滚动条并平滑滚动(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 HTML代码如下 移动端隐藏滚动条解决方案 * { padding: 0; margin: 0; } .par-type { height: 50px; -we…

    好文分享 2025年12月24日
    000
  • CSS实现页面底部固定的方法介绍(附代码)

    本篇文章给大家带来的内容是关于css实现页面底部固定的方法介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 当我们在写页面时经常会遇到页面内容少的时候,footer会戳在页面中间或什么?反正就是不在最底部显示,反正就是很难看,下面要讲的布局就是解决如何使元素粘住浏览器底…

    好文分享 2025年12月24日
    000
  • 彻底理解CSS中视觉格式化模型(附示例)

    本篇文章给大家带来的内容是关于彻底理解css中视觉格式化模型(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 不论你在什么时候开始,重要的是开始之后不要停止。 前言 对于部分前端工程师来讲,有时候CSS令他们很头疼,明明设置了某个样式,但是布局就是不起作用。 如果你也有这种…

    2025年12月24日
    000
  • css实现等高布局的三种方式(代码示例)

    本篇文章给大家带来的内容是关于css实现等高布局的三种方式(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 本文讲的等高布局是在不手动设置元素高度的情况下,使用纯css实现各个元素高度都相当的效果。如图: 1、使用table-cell实现(兼容IE8) 立即学习“前端免费…

    2025年12月24日
    000
  • 纯CSS实现底层毛玻璃效果(代码示例)

    本篇文章给大家带来的内容是关于纯css实现底层毛玻璃效果(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 毛玻璃背景是一个很常见的网页样式,想要实现,其实并不难,但经过我在网上的搜索发现,大量实现方法都较为不规范,且把问题复杂化了(例如各种z-index属性和positi…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信