如何复制 div onclick 事件?
- 作者: 嗷嗷叫灬
- 来源: 51数据库
- 2022-10-21
问题描述
我希望在单击按钮时复制一个 div.我虽然是这样的;但它不起作用.谁能帮帮我?
I want a div to be duplicated when a button is clicked. I though something like this; but it's not working. Can anyone help me?
HTML
<div id="duplicater"> duplicate EVERYTHING INSIDE THIS DIV </div>
JAVASCRIPT
function duplicate()
{
var div = duplicate("div");
div.id = "duplicater";
div.appendChild(duplicate("duplicater"));
}
推荐答案
你正在创建一个无限递归!
You are creating an infinite recursion!
function duplicate()
{
var div = duplicate("div");
函数一遍又一遍地调用自己.使用 cloneNode():
The function is calling itself over and over again. Use cloneNode():
HTML:
<div id="duplicater0"> duplicate EVERYTHING INSIDE THIS DIV </div>
JavaScript:
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);
}
工作演示
或者没有 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,你可以使用稍微不同的版本:
If you want to clone the div on button click, you can use a slightly different version:
HTML:
<button id="button" onclick="duplicate()">Click me</button>
<div id="duplicater">
duplicate EVERYTHING INSIDE THIS DIV
</div>
JavaScript:
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">.
If you are not in a form, you should use <button> instead of <input type="button">.
工作演示 2
推荐阅读
热点文章
检查拆分键盘
0
带有“上一个"的工具栏和“下一个"用于键盘输入AccessoryView
0
Activity 启动时显示软键盘
0
UIWebView 键盘 - 摆脱“上一个/下一个/完成"酒吧
0
在 iOS7 中边缘滑动时,使键盘与 UIView 同步动画
0
我的 iOS 应用程序中的键盘在 iPhone 6 上太高了.如何在 XCode 中调整键盘的分辨率?
0
android:inputType="textEmailAddress";- '@' 键和 '.com' 键?
0
禁用 iPhone 中键盘的方向
0
Android 2.3 模拟器上的印地语键盘问题
0
keyDown 没有被调用
0
