当前位置:首页 > JavaScript

js 实现append()

2026-01-31 16:17:36JavaScript

实现 append() 方法

在 JavaScript 中,可以通过多种方式实现类似 append() 的功能,用于向 DOM 元素添加子节点或内容。以下是几种常见方法:

使用 appendChild() 方法

appendChild() 是原生 DOM 方法,用于向指定父节点添加子节点:

const parent = document.getElementById('parent');
const child = document.createElement('div');
child.textContent = 'New child';
parent.appendChild(child);

使用 insertAdjacentHTML() 方法

insertAdjacentHTML() 可以在指定位置插入 HTML 字符串:

js 实现append()

const parent = document.getElementById('parent');
parent.insertAdjacentHTML('beforeend', '<div>New child</div>');

使用 innerHTML 属性

通过修改 innerHTML 可以添加 HTML 内容:

const parent = document.getElementById('parent');
parent.innerHTML += '<div>New child</div>';

使用现代 append() 方法

js 实现append()

现代浏览器支持 append() 方法,可以一次添加多个节点或字符串:

const parent = document.getElementById('parent');
const child1 = document.createElement('div');
child1.textContent = 'Child 1';
const child2 = 'Child 2 text';
parent.append(child1, child2);

自定义 append() 函数

如果需要创建一个自定义的 append() 函数来统一不同方法的调用方式:

function append(parent, ...children) {
  if (typeof parent.append === 'function') {
    parent.append(...children);
  } else {
    children.forEach(child => {
      if (typeof child === 'string') {
        parent.insertAdjacentHTML('beforeend', child);
      } else {
        parent.appendChild(child);
      }
    });
  }
}

性能考虑

当需要频繁操作 DOM 时,使用 DocumentFragment 可以提高性能:

const fragment = document.createDocumentFragment();
for (let i = 0; i < 100; i++) {
  const div = document.createElement('div');
  div.textContent = `Item ${i}`;
  fragment.appendChild(div);
}
document.getElementById('container').appendChild(fragment);

注意事项

直接使用 innerHTML 会替换元素内的所有内容,可能导致事件监听器丢失。对于动态内容,推荐使用 createElementappendChild 组合。

现代浏览器中,append() 方法支持同时添加多个节点和文本节点,是最高效的方式。对于需要支持旧浏览器的项目,可以使用 polyfill 或上述自定义函数。

标签: jsappend
分享给朋友:

相关文章

js实现图片上传

js实现图片上传

图片上传的基本实现 使用HTML的<input type="file">元素配合JavaScript的File API可以实现图片上传功能。HTML部分需要创建一个文件选择输入框和一个用于…

使用js实现

使用js实现

使用JavaScript实现 JavaScript可以通过Math.random()函数生成随机数,结合其他方法可以实现多种随机数生成需求。 // 生成0到1之间的随机小数 const random…

js节流实现

js节流实现

节流的概念 节流(Throttle)是一种限制函数执行频率的技术,确保函数在一定时间间隔内只执行一次。常用于滚动事件、窗口调整等高频触发的场景。 基础实现方法 使用时间戳判断是否执行函数: fun…

js实现图片

js实现图片

图片加载与显示 在JavaScript中,可以通过Image对象动态加载图片。创建实例后设置src属性触发加载,通过onload回调处理加载完成后的操作: const img = new Ima…

js实现的游戏

js实现的游戏

JavaScript 游戏开发基础 JavaScript 是开发网页游戏的流行选择,因其无需插件即可在浏览器中运行。以下是一些关键技术和资源: HTML5 Canvas Canvas 提供了绘制图形…

js实现排序

js实现排序

数组排序方法 JavaScript提供了内置的sort()方法用于数组排序。默认情况下,sort()将元素转换为字符串并按照Unicode码点排序。对于数字排序,需传入比较函数。 const num…