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 標籤移除即可,因為腳本已經執行過,移除它的標籤並不會造成影響,如下:
function cloneNode(dom){ var scripts dom.getElementsByTagName("script");
for(var i = scripts - 1, s; i >= 0; i --){
s = scripts[i];
s.parentNode. removeChild(s);
}
return dom.cloneNode(true);
}
因此,我們在使用cloneNode(true) 時一定要注意思考:所複製節點內的所有子節點是否都是需要的?盡量把不需要的都乾掉,避免造成負作用影響,再舉個例子,如果複製div 中包含iframe,而iframe 的頁面裡有腳本parent.xxx…,那麼iframe 裡的這些腳本必然會再重新執行一次,iframe 頁本身沒問題(也不一定),但由於它操作了parent,那麼這個parent 造成的影響就難以估量了。解決方法是 cloneNode 之後,把副本裡包含的 iframe 幹掉,當然,如果劇情所需,iframe 不能幹掉的話,就在 iframe 頁裡的腳本自行做判斷了。
另外,cloneNode 目標節點內包含 link 標籤的話,這個估計也會有些影響,我沒有做實驗,如果沒用的話,也是 removeChild 了之,以絕後患。

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver Mac版
視覺化網頁開發工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Dreamweaver CS6
視覺化網頁開發工具