2013-06-05 2 views
16

Я клонирую текстовую область на странице, но клонированный элемент не имеет никакого события первичного элемента, есть ли способ клонировать все события в клонированном элементе?Клонировать элемент со всеми его событиями

var dupNode = node.cloneNode(deep); 
+0

Возможный дубликат [как скопировать узел DOM с прослушивателями событий?] (Http://stackoverflow.com/questions/15408394/how-to-copy-a -dom-node-with-event-listeners) – Nickolay

ответ

7

Возможно использование getEventListeners на узлах? Не знаете, как поддерживается поддержка, или если она поддерживается только в консоли?

function cloneMassive(node) { 
    // Clone the node, don't clone the childNodes right now... 
    var dupNode = node.cloneNode(false); 
    var events = getEventListeners(node); 

    for(var p in events) { 
     // All events is in an array so iterate that array: 
     events[p].forEach(function(ev) { 
      // {listener: Function, useCapture: Boolean} 
      dupNode.addEventListener(p, ev.listener, ev.useCapture); 
     }); 
    } 
    // Also do the same to all childNodes and append them. 
    if (node.childNodes.length) { 
     [].slice.call(node.childNodes).forEach(function(node) { 
      dupNode.appendChild(cloneMassive(node)); 
     }); 
    } 

    return dupNode; 
} 

var dupBody = cloneMassive(document.body); 

Но мне кажется, что getEventListeners на самом деле не поддерживаются:

Get event listeners attached to node using addEventListener


Если вам нужно скопировать все свойства событий на узле, а вы потребуется список всех, а затем просто скопируйте их:

['onclick', 'onmouseover', '...'].forEach(function(method) { 
    dupNode[method] = node[method]; 
}); 
-2

Я решал эту проблему в последнее время, и даже, что это старый пост, на всякий случай, кто-то пытается выяснить, я добавить мое решение:

var button = document.createElement("i"); 
var click = document.createAttribute("onclick"); 
click.value = "FunctionName(this)"; 
button.attributes.setNamedItem(click); 

Вместо использования addEventListener, просто создать функцию FunctionName. Ну, это бесполезно, если вы расширяете объекты, которые используют addEventListener

+0

Как это отвечает на вопрос OP? Что такое 'startRecorind'? Что такое 'typ'? – m02ph3u5

Смежные вопросы