当前位置:首页 > 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实现复制

使用document.execCommand方法 在较旧的浏览器中,可以使用document.execCommand('copy')实现复制功能。创建一个临时的textarea或input元素,将需要…

js实现继承

js实现继承

原型链继承 通过将子类的原型指向父类的实例实现继承。子类实例可以访问父类原型上的属性和方法。 function Parent() { this.name = 'parent'; } Parent…

js 实现继承

js 实现继承

原型链继承 通过让子类的原型对象指向父类的实例来实现继承。子类实例可以访问父类原型上的属性和方法。 function Parent() { this.name = 'parent'; } Par…

js 实现分页

js 实现分页

实现分页的基本逻辑 分页功能通常需要后端返回数据总量或总页数,前端根据当前页码和每页条数截取对应数据。以下是一个基于JavaScript的简单分页实现方案: 前端分页实现 假设已有从后端获取的完整数…

js实现拷贝

js实现拷贝

实现文本拷贝 使用 document.execCommand 方法(已废弃但兼容性较好): function copyText(text) { const textarea = document…

js实现报表

js实现报表

使用JavaScript实现报表 在JavaScript中实现报表功能可以通过多种方式完成,常见的方法包括使用原生JavaScript、第三方库(如Chart.js、D3.js)或结合后端数据渲染。以…