javascript - 如何复制 div onclick 事件?

标签 javascript html copy duplicates

我希望在单击按钮时复制一个 div。我虽然是这样的;但它不工作。谁能帮帮我?

HTML

<div id="duplicater"> 
duplicate EVERYTHING INSIDE THIS DIV
</div>

JavaScript

function duplicate()
{
var div = duplicate("div");
    div.id = "duplicater";
div.appendChild(duplicate("duplicater"));
}

最佳答案

你正在创建一个无限递归!

function duplicate()
{
    var div = duplicate("div");

该函数一遍又一遍地调用自己。使用 cloneNode() :

HTML:

<div id="duplicater0"> 
duplicate EVERYTHING INSIDE THIS DIV
</div>

JavaScript:

var i = 0;

function duplicate() {
    var original = document.getElementById('duplicater' + i);
    var clone = original.cloneNode(true); // "deep" clone
   clone.id = "duplicater" + ++i; // there can only be one element with an ID
    clone.onclick = duplicate; // event handlers are not cloned
    original.parentNode.appendChild(clone);
}

Working DEMO

或者没有 ID:

function duplicate() {
    var clone = this.cloneNode(true); // "deep" clone
    clone.id = ""; // there can only be one element with an ID
    clone.onclick = duplicate; // event handlers are not cloned
    this.parentNode.appendChild(clone);
}

更新:

如果你想在按钮点击时克隆 div,你可以使用稍微不同的版本:

HTML:

<button id="button" onclick="duplicate()">Click me</button>
<div id="duplicater"> 
    duplicate EVERYTHING INSIDE THIS DIV
</div>

JavaScript:

var i = 0;
var original = document.getElementById('duplicater');

function duplicate() {
    var clone = original.cloneNode(true); // "deep" clone
    clone.id = "duplicater" + ++i;
    // or clone.id = ""; if the divs don't need an ID
    original.parentNode.appendChild(clone);
}

如果你不在表格中,你应该使用<button>而不是 <input type="button"> .

Working DEMO 2

关于javascript - 如何复制 div onclick 事件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4427094/

相关文章:

javascript - 使用 jQuery 拆分和修改元素

php - 通过 DOMDocument 获取具有子节点的节点的内容

javascript - 我如何使用 javascript 将这个 bootstrap html 表单传递到下一页?

javascript - 为什么 Object.assign 适用于数组?

copy - iOS9 NSFileManager 请求在 Documents 目录中保存文件的权限

javascript - 如何在 Node 中解码 gzip 或 utf-8 响应?

javascript - jQuery 更改用户的 img

javascript - <a onclick ="someFunction"> 和 <a onclick ="someFunction()"> 有什么区别

python - Pandas 数据框和字典的深度复制

javascript - 使用animationFrame制作抖动动画