在Javascript中方法由两部分组成: 方法名和方法体。 JavaScript中的方法跟其他传统面向对象语言不同,它跟普通的变量没有区别,唯一不同点是它是Function对象,因此它会有一些Function类的属性及方法。
// 声明式square(4); //可以执行,结果为16function square(number) { return number * number;}
// 叙述式var square = function(number) {return number * number;};square(4); //16
通过叙述式定义方法时,可以指定方法的名称,该方法名只能在方法内部进行调用。
// 叙述式, 指定范围内的函数名称// factorial为函数变量, fac为范围内的函数名称,只能在内部进行使用。var factorial = function fac(n) { return n<2 ? 1 : n*fac(n-1) };factorial(10); //3628800fac(5); //ReferenceError: fac is not defined
// 构造方法var sum = new Function("num1", "num2", "return num1 + num2;");sum(4,5); //9
// evaleval('function sum(num1, num2) {return num1 + num2;}');sum(4,5); //9
简单来说闭包是方法内再一次定义方法,内部方法可以访问到外部方法的任何变量,并且在内部方法中使用到的变量的生命周期比外部方法长一些。
var pet = function(name) { // 外部方法定义 name 变量 var getName = function() { return name; // 内部方法使用了外部方法的 name 变量 } return getName; // 返回内部方法,结果在外界可以调用到内部方法。},myPet = pet("Vivie"); myPet(); // Vivie
function outside(x) { function inside(y) { return x + y; } return inside;}fn_inside = outside(3); // 调用了外部方法,传递的x为3,并且返回内部方法result = fn_inside(5); // 调用内部方法,传递y为5, 但因之前传递的x还存在,结果为8result1 = outside(3)(5); // 8
function a() {console.log("a function run");console.log(arguments.callee.caller); // nullb();}function b() {console.log("b function run");console.log(typeof arguments.callee.caller); // a函数}a();
// 像数组一样使用argumentsvar args = [].join.call(arguments, ':');
// arguments转换为数组var args = [].slice.call(arguments)
// applyvar a = {x:"AAA"};function test() {var result = "";result += this.x;for(var i=0; i<arguments.length; i++) {result += arguments[i];}console.log(result);}test.apply(a, [1,2,3,4]); // AAA1234
// callvar a = {x:"AAA"};function test() {var result = "";result += this.x;for(var i=0; i<arguments.length; i++) {result += arguments[i];}console.log(result);}test.call(a, 1,2,3,4); // AAA1234
// bindvar a = {x:"AAA"};function test() {var result = "";result += this.x;for(var i=0; i<arguments.length; i++) {result += arguments[i];}console.log(result);}var bindFunc = test.bind(a, 1,2,3,4); bindFunc(); // AAA1234
function multiply(a, b = 1) { return a*b;}multiply(5); // 5
function multiply(multiplier, ...theArgs) { return theArgs.map(x => multiplier * x);}var arr = multiply(2, 1, 2, 3);console.log(arr); // [2, 4, 6]
var a = [ "Hydrogen", "Helium", "Lithium", "Beryl-lium"];var a2 = a.map(function(s){ return s.length }); // [8, 6, 7, 10]var a3 = a.map( s => s.length ); // [8, 6, 7, 10]
MDNMDN ReferenceJavaScript Info: Function expressionsJavaScript Info: Function arguments
新闻热点
疑难解答