給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ù)實際應(yīng)用虛擬的示范代碼
注:變體1應(yīng)用很多,常見寫法如下:
<script type="text/javascript">
// 直接轉(zhuǎn)義即可:
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
和全部變量相比,我們更希望能像下面這樣傳入?yún)?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),但要求文件名唯一。缺點是代碼多,不精煉,對性能也稍有影響。
方法三是在方法一的基礎(chǔ)上,干脆再添加一個自定義屬性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];方法四比方法二更靈巧天才。
從代碼的精簡和性能上講,方法三 > 方法 一 > 方法四 > 方法二
小結(jié):如果你很在意標準,推薦方法四;如果和我一樣覺得沒必要完全遵守標準,推薦方法三。
寫了個測試程序
<!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'));
}
相關(guān)文章
javaScript 計算兩個日期的天數(shù)相差(示例代碼)
本篇文章主要介紹了javaScript 計算兩個日期的天數(shù)相差(示例代碼) 需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12
JavaScript基于libgif.js實現(xiàn)控制gif動畫幀
這篇文章主要為大家詳細介紹了JavaScript如何利用libgif.js插件控制gif動畫幀,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2024-02-02
JavaScript中具名函數(shù)的多種調(diào)用方式總結(jié)
這篇文章主要介紹了JavaScript中具名函數(shù)的多種調(diào)用方式總結(jié),本文總結(jié)了4種方法,需要的朋友可以參考下2014-11-11
使用JS實現(xiàn)鼠標放上圖片進行放大離開實現(xiàn)縮小功能
這篇文章主要介紹了使用JS實現(xiàn)鼠標放上圖片進行放大離開實現(xiàn)縮小功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01
深入理解JavaScript系列(34):設(shè)計模式之命令模式詳解
這篇文章主要介紹了深入理解JavaScript系列(34):設(shè)計模式之命令模式詳解,命令模式(Command)的定義是:用于將一個請求封裝成一個對象,從而使你可用不同的請求對客戶進行參數(shù)化,對請求排隊或者記錄請求日志,以及執(zhí)行可撤銷的操作,需要的朋友可以參考下2015-03-03

