JS中跨頁面調(diào)用變量和函數(shù)的方法(例如a.js 和 b.js中互相調(diào)用)
在項目開發(fā)過程中,也許你會遇這樣的情況。
在某一Js文件中需要完成某一功能,但這一功能的大部分代碼在另外一個Js文件中已經(jīng)完成了,自己只需要調(diào)用這個方法再加上幾句代碼就可以實現(xiàn)所需的功能。
我們知道,在html中,利用<script language="javascript" type="text/javascript" src="./script.js"></script>引入的兩個js是不可以相互調(diào)用的。那么該如何解決呢?當(dāng)然,你可以將代碼通通copy過來,也許你并不喜歡這樣。
例如有這樣一個html,里面有一個按鈕,當(dāng)按下時調(diào)用b.js文件中的方法b()。而b()中又要調(diào)用a.js文件中的方法a()。若要實現(xiàn)這個功能,必須注意,將要引入的Js文件代碼放在</body>下面。
首先,我們在html中引入b.js,并在</body>之后加入引用語句。如下:
<html> <body> <input type="button" value="ok" onClick="javascript:b()"> </body> <!--這里引用要放在body下面--> <script language="JAVASCRIPT" src='b.js'></script> </html>
b.js文件如下:
new_element=document.createElement("script"); new_element.setAttribute("type","text/javascript"); new_element.setAttribute("src","a.js");// 在這里引入了a.js document.body.appendChild(new_element); function b() { a(); }
在b.js文件中前4行代碼中我們引入了a.js文件,并在第7行代碼中調(diào)用了a.js代碼中的a()方法。
讓我們來分析一下關(guān)鍵的幾句代碼:首先,我們利用document.createElement("script")生成了一個script的標(biāo)簽,設(shè)置其type屬性為text/javascript,src為a.js(這里的a.js同b.js放在同一個目錄,也可放在不同的目錄)。最后將這個標(biāo)簽動態(tài)地加入body中。如此一來,我們就可以調(diào)用到不同js文件中的方法了。
以上就是小編為大家?guī)淼腏S中跨頁面調(diào)用變量和函數(shù)的方法(例如a.js 和 b.js中互相調(diào)用)全部內(nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
js下關(guān)于onmouseout、事件冒泡的問題經(jīng)驗小結(jié)
第3次遇到這個問題,于是總結(jié)了一下,將此短文發(fā)在首頁,希望對瀏覽器事件機制有所了解的大俠們給予解答2010-12-12移動端觸屏幻燈片圖片切換插件idangerous swiper.js
這篇文章主要為大家詳細介紹了移動端觸屏幻燈片圖片切換插件idangerous swiper.js的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04深入理解JavaScript系列(11) 執(zhí)行上下文(Execution Contexts)
本章我們要講解的是ECMAScript標(biāo)準(zhǔn)里的執(zhí)行上下文和相關(guān)可執(zhí)行代碼的各種類型2012-01-01