|
復制代碼 代碼如下:
script = document.createElement('script');
script.src =
'http://example.com/cgi-bin/jsonp?q=What+is+the+meaning+of+life%3F';
script.id = 'JSONP';
script.type = 'text/Javascript';
script.charset = 'utf-8';
// 標簽加到head后,會自動加載并運行。
var head = document.getElementsByTagName('head')[0];
head.appendChild(script)
實際上很多流行的JS庫都采用這種方式,創(chuàng)建一個scritp標簽,賦予一個ID后加載腳本(比如YUI get()),加載完并回調(diào)后清除該標簽。問題在于當你清除這些script標簽的時候,瀏覽器僅僅是移除該標簽結(jié)點。
復制代碼 代碼如下:
var script = document.getElementById('JSONP');
script.parentNode.removeChild(script);
當瀏覽器移除這標簽結(jié)點后的同時并沒對結(jié)點內(nèi)JavaScript資源的進行垃圾回收,這意味著移除標簽結(jié)點還不夠,還得手動的清除script標簽結(jié)點的內(nèi)容:
復制代碼 代碼如下:
// Remove any old script tags.
var script;
while (script = document.getElementById('JSONP')) {
script.parentNode.removeChild(script);
// 瀏覽器不會回收這些屬性所指向的對象.
//手動刪除它以免內(nèi)存泄漏.
for (var prop in script) {
delete script[prop];
}
}
JavaScript技術(shù):防止動態(tài)加載JavaScript引起的內(nèi)存泄漏問題,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。