实现不同js中方法相互调用
2016-09-09 15:17
441 查看
如果在同一个页面中,不同Js中的方法是可以相互调用的,如
A.js:
Function aa(obj)(){alert(“faf”);}
此时表示的是在a.js存在着一个js方法,并且这个方法实现了一定的功能。
B.Js:
现在的需求是需要在b.js中要实现一定的功能,而部分功能已经在a.js中的aa()方法中进行了实现,如果再在b.js中再把a.js中的复制过来,如果代码很少,这也是一种解决方法,但是如果a.js中的aa()中的代码量很多,再进行使用复制的方法就行不通了,所以最简单的方法就是在b.js中直接的调用a.js的aa()方法。
两种情况实现:
1)a.js和b.js在同一个页面中
这样实现起来很简单,就直接在b.js中直接使用aa()方法就可以了。
Function bb(){
aa();//此时就直接的调用a.js中的方法就ok
};
2)a.js和b.js不在同一个页面中
在项目开发过程中,也许你会遇这样的情况。在某一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>
<body>
<input type="button" value="ok" onclick="javascript:b()">
</body>
<!--这里引用要放在body下面-->
<script language="JAVASCRIPT" src='b.js'></script>
</html>
b.js文件中引入a.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行代码中调用了a.js代码中的a()方法。
让我们来分析一下关键的几句代码:首先,我们利用document.createElement("script")生成了一个script的标签,设置其type属性为text/javascript,src为a.js(这里的a.js同b.js放在同一个目录,也可放在不同的目录)。最后将这个标签动态地加入body中。如此一来,我们就可以调用到不同js文件中的方法了。
注意:<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错误。
A.js:
Function aa(obj)(){alert(“faf”);}
此时表示的是在a.js存在着一个js方法,并且这个方法实现了一定的功能。
B.Js:
现在的需求是需要在b.js中要实现一定的功能,而部分功能已经在a.js中的aa()方法中进行了实现,如果再在b.js中再把a.js中的复制过来,如果代码很少,这也是一种解决方法,但是如果a.js中的aa()中的代码量很多,再进行使用复制的方法就行不通了,所以最简单的方法就是在b.js中直接的调用a.js的aa()方法。
两种情况实现:
1)a.js和b.js在同一个页面中
这样实现起来很简单,就直接在b.js中直接使用aa()方法就可以了。
Function bb(){
aa();//此时就直接的调用a.js中的方法就ok
};
2)a.js和b.js不在同一个页面中
在项目开发过程中,也许你会遇这样的情况。在某一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>
<body>
<input type="button" value="ok" onclick="javascript:b()">
</body>
<!--这里引用要放在body下面-->
<script language="JAVASCRIPT" src='b.js'></script>
</html>
b.js文件中引入a.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行代码中调用了a.js代码中的a()方法。
让我们来分析一下关键的几句代码:首先,我们利用document.createElement("script")生成了一个script的标签,设置其type属性为text/javascript,src为a.js(这里的a.js同b.js放在同一个目录,也可放在不同的目录)。最后将这个标签动态地加入body中。如此一来,我们就可以调用到不同js文件中的方法了。
注意:<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错误。
相关文章推荐
- 用js实现多域名不同文件的调用方法
- 用js实现多域名不同文件的调用方法
- dialog使用方法(同一页面,调用一个js代码,实现多个不同样式的弹窗)
- android之通过webview实现与js方法相互调用,数据交互
- android和JS交互,相互调用方法传值。不使用第三方实现原生加载word、ppt、pdf文档
- js实现调用方法(函数)时可动态传入不同参数个数、模拟实现方法(函数)重载
- asp.net中js调用服务端方法,服务端调用JS,实现无刷新的倒计时
- DedeCMS V5.3实现js调用站外调用的方法
- 不用AJAX实现前台JS调用后台C#方法
- js与C#之间相互调用的一些方法
- 不用AJAX实现前台JS调用后台C#方法(小技巧)-转
- JavaScript 实现父,子页面(窗口)方法之间的相互调用
- 不用AJAX实现前台JS调用后台C#方法(小技巧) (转)
- js实现根据浏览器类型自动调用不同CSS文件[收藏]
- js与C#之间相互调用的一些方法
- 不用AJAX实现前台JS调用后台C#方法(小技巧)
- 利用sender的Parent获取GridView中的当前行 不用AJAX实现前台JS调用后台C#方法(小技巧) AjaxControlToolkit的CalendarExtender的本地化
- 不同编码网站内容之间的JS调用方法
- 不用AJAX实现前台JS调用后台C#方法(小技巧) 【改自Web.网际浪人.Blog】