如何在js文件中调用另一个js中的方法(详细请进)

JavaScript019

如何在js文件中调用另一个js中的方法(详细请进),第1张

方法:直接调用对方的函数就行。

步骤:

     1、两个或者多个js文件加载到同一个页面中

     2、js文件中的方法直接相互访问。

示例:

a.js中定义一个方法

function a(){

}

b.js中定义一个方法

function b(){

}

在a.js中访问b.js中方法

b()//就可以直接访问b方法

我们知道,在html中,利用<script language="javascript" type="text/javascript" src="./script.js"></script>引入的两个js是不可以相互调用的。那么该如何解决呢?当然,你可以将代码通通copy过来,也许你并不喜欢这样。

例如有这样一个html,里面有一个按钮,当按下时调用b.js文件中的方法b()。而b()中又要调用a.js文件中的方法a()。若要实现这个功能,必须注意,将要引入的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行代码中调用了a.js代码中的a()方法。

让我们来分析一下关键的几句代码:首先,我们利用document.createElement("script")生成了一个script的标签,设置其type属性为text/javascript,src为a.js(这里的a.js同b.js放在同一个目录,也可放在不同的目录)。最后将这个标签动态地加入body中。如此一来,我们就可以调用到不同js文件中的方法了。

如果是最典型的构造函数模式,必须加上new:

function Man(age){

this.sex="male"

this.age=age

}

m1=Man(20)

m2=new Man(21)

m1就是函数Man()执行的返回值,也就是undefined. 在函数执行过程中,属性被加到全局作用域或者Man方法所属的对象上了。执行之后window.sex=="male"

而m2是Man的实例,Man {sex:"male",age:21}

function Man(age) {

var obj = new Object()

obj.sex = "mail"

obj.age = age

return obj

}

m3=Man(22)

这个就不需要加new,m3是一个Object,不是Man的实例。

native code中,加new就是返回这个构造函数的实例;不加作为函数就返回一个基本数据类型,或者会报错 “ DOM object constructor cannot be called as a function ”。

Date(),不加new返回当前时间,是一个字符串。加new的话,返回当前时间或者把参数格式化得到的时间,是一个Date对象。

String(),不加new将参数格式化为字符串,加new则返回的是String对象。它们的区别如下:

var s1=new String(2)

//如果把s1 log到控制台中,输出 String{0:"2"}

var s2=String(2)

//如果把s2 log到控制台中,输出 '2'

console.log(typeof s1)

//"object"

console.log(typeof s2)

//"string"

s1.pro = 1

console.log(s1.pro)

//1

s2.pro = 1

console.log(s2.pro)

//undefined

Number和String类似。

Array,Object加不加new貌似是一样的?

Image,XMLHttprequest等不能作为函数使用。