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