cloneNode 是 HtmlElement 原型鏈上的方法,用於建立指定 dom 節點的拷貝,它接受一個布林參數 include_all,如果 include_all 設為 true,則副本會帶有指定節點的所有子節點。
然而,script 標籤也是dom 節點,cloneNode 對其依然有效,經實測各瀏覽器(尤其是IE)對cloneNode 執行結果表現不一致,主要現象為以下兩種:
IE,至少是IE8 及以下,對某節點cloneNode 時,如果該節點包含script 節點,那麼script 節點的腳本內容「有可能」會再次執行一次。
非 IE 瀏覽器,cloneNode 某節點,包含的 script 節點的腳本內容不會再執行一次。
IE 以外的瀏覽器表現令我很滿意,而針對於上面所述IE 的“有可能”,還分以下兩種情況:
如果cloneNode 一個script 節點,無論該節點是外鏈腳本,還是內嵌腳本,均不會再次執行。
如果 cloneNode 一個其它節點,則該節點下包含的內嵌腳本不會被執行,而包含的外鏈腳本,會再次執行一次。
這裡有一個 demo 復現了 IE 下 cloneNode 的這個問題。
看到這裡,你是不是要被繞暈了?解決方法很簡單,不用管是什麼瀏覽器,cloneNode 之前,把目標節點下所有的script 標籤移除即可,因為腳本已經執行過,移除它的標籤並不會造成影響,如下: