Js文件中調用其它Js函數的方法

Js文件中調用其它Js函數的方法javascript

  在項目開發過程當中,也許你會遇這樣的狀況。在某一Js文件中須要完成某一功能,但這一功能的大部分代碼在另一個Js文件中已經完成了,本身只須要調用這個方法再加上幾句代碼就能夠實現所需的功能。咱們知道,在html中,利用
<script language="javascript" type="text/javascript" src="../script.js"></script>
引入的兩個js是不能夠相互調用的。那麼該如何解決呢?固然,你能夠將代碼統統copy過來,這樣會讓你的b.js會變得很長,也許已經影響到了你對b.js的定位了,檢查,維護都會變得麻煩.
  例若有這樣一個html,裏面有一個按鈕,當按下時調用b.js文件中的方法b()。而b()中又要調用a.js文件中的方法a()。那咱們應該怎麼作呢?
  首先,咱們在html中引入b.js,並在</body>以後加入引用語句。必須注意,將要引入的Js文件代碼放在</body>下面。
html

<html>
  
<body>
     
<input type="button" value="ok" onclick="javascript:b()">
  
</body>
 
 
<!--這裏引用要放在body下面-->
 
<script language="JAVASCRIPT" src='b.js'></script>
 
</html>
java


  b.js文件中引入a.js,內容以下:app

 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行代碼中調用了a.js代碼中的a()方法。

  讓咱們來分析一下關鍵的幾句代碼:首先,咱們利用document.createElement("script")生成了一個script的標籤,設置其type屬性爲text/javascript,src爲a.js(這裏的a.js同b.js放在同一個目錄,也可放在不一樣的目錄)。最後將這個標籤動態地加入body中。如此一來,咱們就能夠調用到不一樣js文件中的方法了。spa

注意:<script language="JAVASCRIPT" src='b.js'></script>必定要放在body下面。
由於在b.js中用到了body(document.body.appendChild(new_element);)
若是將引如b.js的代碼放在body上面,也就是說,
進入頁面後,尚未生成body就已經執行b.js裏的document.body.appendChild(new_element);了。
這時body不存在就會拋javascript錯誤。.net



搞了一個小時才搞出來,真的是累死人。。。。
htm

相關文章
相關標籤/搜索