上节咱们介绍了《JavaScript工做体系中不可或缺的函数》,函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块。接下来咱们说说js当中定义(声明)函数的几种方式,以及每种方式的特色和与其余方式的区别。html
一、 函数式声明html5
function funName(arg1, arg2)
{设计模式
alert(arg1 + “,” + arg2);
}函数
特色:此种方式可定义命名的函数变量,而无需给变量赋值,这是一种独立的结构,不能嵌套在非功能模块中。函数名在自身做用域和父做用域内是可获取的(其余域是娶不到的)。当解析器读取js代码时,会先读取函数的声明,此种方式定义的函数在执行任何代码以前均可以访问(调用)。this
二、 函数表达式(函数字面量)prototype
var fun = function(arg1, arg2){设计
alert(arg1 + “,” + arg2);
}
var fun = function funName(arg1,arg2){code
alert(arg1 + “,” + arg2);
}htm
(function hello(){对象
alert(“HelloWorld!!!”);
})(); // 自调用
特色:地中方式是将函数定义为表达式语句的一部分。函数能够是命名的也能够是匿名的。并且必须等到解析器执行到它所在的代码行才能真正被解释执行。
三、 函数构造法,参数必须加引号
var fun = new Function(‘arg1’, ‘arg2’, ‘alert(arg1 + “,” + arg2)’);
特色:从技术角度讲,这是一个函数表达式。可是通常不推荐这种方式。
四、 对象直接量
var obj = {
name : “”, getName : function(){ return this.name;
},
setName : function(name){
this.name = name;
}
};
特色:将方法的定义看作为一个对象的成员变量,此时对象的变量值为一个方法,经过访问该对象的属性名称,达到调用方法的效果。
五、 原型继承
var obj = new Function();
obj.prototype = {
name : “”, getName : function(){ return this.name;
},
setName : function(name){
this.name = name;
}
};
特色:定义了一个函数对象,在其原型对象中定义方法。在使用prototype的方法时,必须实例化该对象才能调用其方法。
六、 工厂模式
function obj(){
var temp = new Object();
temp.name = “”;
temp.getName = function(){
return this.name;
};
temp.setName(name){
this.name = name;
};
return temp;
}
特色:工厂模式是软件工程领域一种广为人知的设计模式,因为在ECMAScript中没法建立类,所以用函数封装以特定接口建立对象。即在一个函数内建立一个对象,给对象赋予属性和方法再将其对象返回。
以上介绍的几种js中建立方法经常使用的方式,根据其特色和理解能够根据实际状况使用不一样的方式声明函数。