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

給js文件傳參數(shù)(詳解)

 更新時間:2014年07月13日 15:43:12   投稿:mdxy-dxy  
這篇文章主要介紹了給js文件傳參數(shù)的方法,需要的朋友可以參考下

一、利用全局變量

這是最簡單的一種方式,比如Google Adsense:

復制代碼 代碼如下:

<script type="text/javascript"> google_ad_client ='pub-3741595817388494'; </script> <script type="text/javascript" src="http://pagead2. googlesyndication.com/pagead/show_ads.js"></script>

缺點是引入了全局變量。其中引入文件的方式還有兩個變體:

// 變體1:用document.write輸出
 <script type="text/javascript"> google_ga_id ='g6u7un8646xx'; 
document.write(unescape('%3Cscript type="text/javascript" src= "http://www.google-analytics.com/ga.js"%3E%3C/script%3E')); </script> 
// 變體2:用DOM操作append到head里 
<script type="text/javascript"> 
G_BEACON_ATP ='category=&userid=&channel=112ad_id=';
 document.getElementsByTagName('head')[0].appendChild(document. createElement('script')).src='http://taobao.com/atp.js'; 
</script> // 注意:上面的代碼是根據(jù)實際應用虛擬的示范代碼

注:變體1應用很多,常見寫法如下:

<script type="text/javascript"> 
// 直接轉義即可: 
document.write('<script type="text/javascript" src="test.js"></script>'); 
// 或者像Yahoo!首頁一樣: 
document.write('<scr'+'ipt type="text/javascript" src="test.js"></scr'+'ipt>');
</script>

二、獲取并解析script元素的src

和全部變量相比,我們更希望能像下面這樣傳入參數(shù):

<script type="text/javascript" src="test.js?a=b&c=d"></script>

核心問題是如何獲取到src屬性。

方法一是給script添加id屬性,通過id得到當前script,再用正則從src中取出參數(shù)。缺點是HTML 4.01 Specification里,SCRIPT元素沒有id屬性。這個缺點也算不得是缺點,畢竟盡信標準不如無標準。

方法二是用js的文件名當作鉤子,js代碼里通過document.getElementsByTagName('script')后,正則匹配出當前js文件。這個方法很正統(tǒng),但要求文件名唯一。缺點是代碼多,不精煉,對性能也稍有影響。

方法三是在方法一的基礎上,干脆再添加一個自定義屬性data:

<script id="testScript" type="text/javascript" src="test.js" data="a=b&c=d"></script>

test.js文件里,通過下面這行得到傳入的參數(shù):

var scriptArgs = document.getElementById('testScript').getAttribute('data');方法四是利用js的順序執(zhí)行機制(js文件的加載可以是同步或異步方式,但執(zhí)行時,一定是按照在文檔流中的順序來執(zhí)行的)。當某個js文件執(zhí)行時,一定是“已加載”的js文件中的最后一個:

var scripts = document.getElementsByTagName('script'); var currentScript = scripts[scripts.length - 1];方法四比方法二更靈巧天才。

從代碼的精簡和性能上講,方法三 > 方法 一 > 方法四 > 方法二

小結:如果你很在意標準,推薦方法四;如果和我一樣覺得沒必要完全遵守標準,推薦方法三。

寫了個測試程序

<!DOCTYPE html>
<html>
<script src="a2.js">
</script>
<script src="a2.js">
</script>
<script src="a2.js">
</script>
</html>

a2.js

var scripts = document.getElementsByTagName('script'); var currentScript = scripts.length;alert(currentScript);

分別打印出 

1 2 3

三、靈感方案

如果你和我一樣是John Resig的忠實fans,或許還記得去年8月份討論得很火爆的《Degrading Script Tags》。John Resig給我們開啟了一扇想象的門,對于本文的問題來說,還可以用以下“邪門歪道”來實現(xiàn):

<script type="text/javascript" src="test.js"> TB.SomeApp.scriptArgs ='a=b&c=d'; </script>

在test.js文件里:

TB = {}; TB.SomeApp = {}; 
var scripts = document.getElementsByTagName("script");
eval(scripts[ scripts.length - 1 ].innerHTML);

這樣就將參數(shù)存儲到了TB.SomeApp.scriptArgs變量里。

當參數(shù)不多時,甚至可以這樣:

<script type="text/javascript" src="test.js">a=b&c=d</script>

js文件里:

var scripts = document.getElementsByTagName("script"); 
var scriptArgs = scripts[ scripts.length - 1 ].innerHTML.replace(/[s]/g, '');

想象是無止境的,還可以利用onload:

<script type="text/javascript" src="test.js" onload="TB.SomeFun('a=b&c=d')"></script>

js文件里定義好函數(shù)即可:

TB = {}; 
TB.SomeFun = function(arg) { 
//code
};

上面的代碼在非ie瀏覽器下,都能正確運行。針對笨笨的ie,還得加幾行代碼:

if(window.ActiveXObject) { 
var scripts = document.getElementsByTagName('script'); 
eval(scripts[scripts.length - 1].getAttribute('onload'));
}

相關文章

  • JavaScript的Set數(shù)據(jù)結構詳解

    JavaScript的Set數(shù)據(jù)結構詳解

    這篇文章主要為大家介紹了JavaScript的Set數(shù)據(jù)結構,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • JavaScript可選鏈的實現(xiàn)示例

    JavaScript可選鏈的實現(xiàn)示例

    本文主要介紹了JavaScript可選鏈的實現(xiàn)示例,它通過使用問號(?)來判斷屬性或函數(shù)是否存在,避免了因為屬性或函數(shù)不存在而導致的錯誤,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • 關于js二維數(shù)組和多維數(shù)組的定義聲明(詳解)

    關于js二維數(shù)組和多維數(shù)組的定義聲明(詳解)

    下面小編就為大家?guī)硪黄P于js二維數(shù)組和多維數(shù)組的定義聲明(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • 詳解微信小程序canvas圓角矩形的繪制的方法

    詳解微信小程序canvas圓角矩形的繪制的方法

    這篇文章主要介紹了詳解微信小程序canvas圓角矩形的繪制的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • 微信小程序Echarts圖表組件使用方法詳解

    微信小程序Echarts圖表組件使用方法詳解

    這篇文章主要介紹了微信小程序Echarts圖表組件使用方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,
    2019-06-06
  • 微信小程序實戰(zhàn)之仿android fragment可滑動底部導航欄(4)

    微信小程序實戰(zhàn)之仿android fragment可滑動底部導航欄(4)

    這篇文章主要為大家詳細介紹了微信小程序實戰(zhàn)之仿android fragment可滑動的底部導航欄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 微信小程序實現(xiàn)日歷功能

    微信小程序實現(xiàn)日歷功能

    這篇文章主要為大家詳細介紹了微信小程序實現(xiàn)日歷功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • Moment.js常見用法總結

    Moment.js常見用法總結

    這篇文章主要介紹了Moment.js常見用法總結,需要的朋友可以參考下
    2022-05-05
  • ES6擴展運算符和rest運算符用法實例分析

    ES6擴展運算符和rest運算符用法實例分析

    這篇文章主要介紹了ES6擴展運算符和rest運算符用法,結合實例形式分析了ES6擴展運算符和rest運算符基本功能、用法及操作注意事項,需要的朋友可以參考下
    2020-05-05
  • javascript模擬實現(xiàn)ajax加載框實例

    javascript模擬實現(xiàn)ajax加載框實例

    這篇文章主要介紹了javascript模擬實現(xiàn)ajax加載框的方法,實例簡述了其實現(xiàn)過程,方法簡單實用,需要的朋友可以參考下
    2014-10-10

最新評論