欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS動(dòng)態(tài)插入腳本和插入引用外部鏈接腳本的方法

 更新時(shí)間:2018年05月21日 16:32:18   投稿:mrr  
js 動(dòng)態(tài)插入腳本的是在頁面加載時(shí)不存在,但將來的某一時(shí)刻通過修改該 DOM 動(dòng)態(tài)添加的腳本。接下來通過本文給大家介紹JS動(dòng)態(tài)插入腳本和插入引用外部鏈接腳本,需要的朋友可以參考下

在日常開發(fā)中,經(jīng)常遇到 js 動(dòng)態(tài)插入腳本 。

什么是 js 動(dòng)態(tài)插入腳本 ?

指的是在頁面加載時(shí)不存在,但將來的某一時(shí)刻通過修改該 DOM 動(dòng)態(tài)添加的腳本。和操作 HTML 元素一樣。

js 動(dòng)態(tài)插入腳本也有兩種方式:插入 JavaScript 代碼和插入外部文件。

一、直接插入 javascript 代碼

<script type="text/javascript">
function sayHi() {
 alert("hi");
}
</script>

從邏輯上講,下面的 DOM 代碼是有效的:

var script = document.createElement("script");
script.type = "text/javascript";
script.appendChild(document.createTextNode("function sayHi() {alert('hi');}"));
document.body.appendChild(script);

在 Firefox、Safari、Chrome 和 Opera 中,這些 DOM 代碼可以正常運(yùn)行。但在 IE 中,則會(huì)導(dǎo)致錯(cuò)誤。IE 將 <script> 視為一個(gè)特殊的元素,不允許 DOM 訪問其子節(jié)點(diǎn)。不過,可以使用

<script> 元素的 text 屬性來指定 JavaScript 代碼,想下面的例子這樣:

var script = document.creatElement("script");
script.type = "text/javascript";
script.text = "function sayHi() {alert('hi');}";
document.body.appendChild(script);

經(jīng)過修改之后的代碼可以在 IE、Firefox、Opera 和 Safari3.0 中運(yùn)行。Safari3.0 之前的版本雖然不能正確的支持 text 屬性,但卻允許使用文本節(jié)點(diǎn)技術(shù)來指定代碼。如果需要兼容早期版本的 Safari,可以使用下列代碼:

var script = document.createElement("script");
script.type = "type/javascript";
var code = "function sayHi() {alert('hi');}";
try {
 script.appendChild(document.createTextNode(code));
} catch (ex) {
 script.text = code;
}
document.body.appendChild(script)

這里首先嘗試標(biāo)準(zhǔn)的 DOM 文本節(jié)點(diǎn)方法,因?yàn)槌?IE(在 IE 中會(huì)導(dǎo)致拋出錯(cuò)誤),所有的瀏覽器都支持之中方式。如果這行代碼拋出了錯(cuò)誤,那么說明是 IE,于是就必須使用 text 屬性了,整個(gè)過程可以用以下函數(shù)來表示:

function loadScriptString(code) {
 var script = document.createElement("script");
 script.type = "text/javascript";
 try {
 script.appendChild(document.createTextNode(code));
 } catch (ex) {
 script.text = code;
 }
 document.body.appendChild(script);
}
loadScriptString("function sayHi() {alert('hi');}");;

二、插入引用外部文件

動(dòng)態(tài)加載外的外部 JavaScript 文件能夠立即運(yùn)行,比如下面的 <script> 元素。

<script type="text/javascript" src="client.js"></script>

而創(chuàng)建這個(gè)節(jié)點(diǎn)的 DOM 代碼如下所示:

var script = document.createElement("script");
script.type = "text/javascript";
script.src = "client.js";
document.body.appendChild(script);

顯然這里的 DOM 如實(shí)的反映了相應(yīng)的 HTML 代碼。不過執(zhí)行最后一行代碼把 <script> 元素添加到頁面之前,是不會(huì)下載外部文件的。也可以把這個(gè)元素添加到 <head> 元素中效果相同。

但是怎么知道這個(gè)腳本文件加載完成了呢,因?yàn)槲覀冇行┖瘮?shù)需要在腳本加載完成生效后才能開始執(zhí)行。

經(jīng)過對網(wǎng)絡(luò)上資源的搜索,我發(fā)現(xiàn)在 IE 瀏覽器中可以使用 <script> 元素的 onreadystatechange 來監(jiān)控加載狀態(tài)的改變,并通過判斷它的 readyState 是 loaded 或 complete 來判斷腳本是否加載完成。而非 IE 瀏覽器可以使用 onload 來直接判斷腳本是否加載完成。

所以一個(gè)簡單的實(shí)現(xiàn)過程看上去是下面這樣的:

IE 下:

var script = document.createElement("script");
var url = 'http:';
script.setAttribute("type","text/javascript");
script.onreadystatechange = function() {
 if(this.readyState == "loaded" || this.readyState == "complete"){
 alert("加載成功啦!");
 }
}
script.setAttribute("src", url);

Opera、FF、Chrome 等:

var script = document.createElement("script");
var url = 'http';
script.setAttribute("type","text/javascript");
script.onload = function() {
 alert("加載成功啦!");
}
script.setAttribute("src",url);

最后可以合并一個(gè) js 動(dòng)態(tài)插入腳本 的 function ;

function loadScript(url, callback) {
 callback = typeof callback === 'function' ? callback : function() {};
 var head = document.getElementsByTagName('head')[0];
 var script = document.createElement('script');
 script.type = 'text/javascript';
 script.src = url; 
 script.onreadystatechange = function() {
 if(this.readyState == "loaded" || this.readyState == "complete"){
  callback();
 }
 }
 script.onload = callback;
 head.appendChild(script);
}

總結(jié)

以上所述是小編給大家介紹的JS動(dòng)態(tài)插入腳本和插入引用外部鏈接腳本的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 用JavaScript實(shí)現(xiàn)仿Windows關(guān)機(jī)效果

    用JavaScript實(shí)現(xiàn)仿Windows關(guān)機(jī)效果

    用JavaScript實(shí)現(xiàn)仿Windows關(guān)機(jī)效果...
    2007-03-03
  • 微信小程序自定義toast彈窗效果的實(shí)現(xiàn)代碼

    微信小程序自定義toast彈窗效果的實(shí)現(xiàn)代碼

    微信小程序里面的自帶彈窗icon只有兩種,success和loading。這篇文章主要介紹了微信小程序之自定義toast彈窗效果的實(shí)現(xiàn)代碼 ,需要的朋友可以參考下
    2018-11-11
  • 簡易 Javascript 調(diào)試包 Debug包

    簡易 Javascript 調(diào)試包 Debug包

    來看一個(gè)簡易的 Javascript 調(diào)試包 jscript.debug.js,包含兩個(gè)函數(shù)
    2010-10-10
  • 最新評論