兩種動態加載JavaScript文件的方法
第一種便是利用ajax方式,第二種是,動靜創建一個script標簽,配置其src屬性,經過把script標簽拔出到頁面head來加載js,感樂趣的網友可以看下
動態加載script到頁面大約有倆方法
第一種便是利用ajax方式,把script文件代碼從背景加載到前台,而后對加載到的內容經過eval()實施代碼。第二種是,動靜創建一個script標簽,配置其src屬性,經過把script標簽插入到頁面head來加載js,相當於正在head中寫了一個<script src="..."></script>,只可是這個script標簽是用js動靜創建的比喻說是我們要動靜地加載一個callbakc.js,我們就必要多么一個script標簽:
代碼如下:
<script type="text/javascript" src="call.js"></script>
代碼如下:
var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.src= 'call.js'; head.appendChild(script);
var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.onreadystatechange= function () { if (this.readyState == 'complete') callback(); } script.onload= function(){ callback(); } script.src= 'helper.js'; head.appendChild(script);
- uninitialized
- loading
- loaded
- interactive
- complete
參考jQuery的實現我們最后實現為: 代碼如下:
var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.onload = script.onreadystatechange = function() { if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete" ) { help(); // Handle memory leak in IE script.onload = script.onreadystatechange = null; } }; script.src= 'helper.js'; head.appendChild(script);
另外需要注意:
1.因為script標簽的src可以跨域訪問資源,所以這種方法可以模擬ajax,解決ajax跨域訪問的問題。
2.如果用ajax返回的html代碼中包含script,則直接用innerHTML插入到dom中是不能使html中的script起作用的。粗略的看了下jQuery().html(html)的原代碼,jQuery也是先解析傳入的參數,剝離其中的script代碼,動態創建script標簽,所用jQuery的html方法添加進dom的html如果包含script是可以執行的。如:
jQuery("#content").html("<script>alert('aa');<\/script>");