我认为你应该使用.clone()方法的这个重载:
$element.clone(true, true);
克隆( [withDataAndEvents] [, deepWithDataAndEvents] )
withDataAndEvents:一个布尔值,指示事件处理程序和数据是否应与元素一起复制。默认值为假。
deepWithDataAndEvents:一个布尔值,指示是否应复制克隆元素的所有子项的事件处理程序和数据。默认情况下,它的值与第一个参数的值匹配(默认为 false)。
请注意,.on()
这实际上并未将事件绑定到目标,而是绑定到您委托给的元素。所以如果你有:
$('#container').on('click', '.button', ...);
这些事件实际上绑定到#container
. 当点击一个.button
元素时,它会冒泡到#container
元素触发事件的元素根据选择器参数进行评估.on()
,如果匹配,则执行事件处理程序。这就是事件委托的工作方式。
如果您克隆元素#container,则必须使用.on()
要保留的绑定的事件和数据进行深度克隆。
如果您.on()
在#container
.