标签:
本文是金旭亮老师网易云课堂的课程笔记,记录下来,以供备忘
除非在另一个函数内部定义,否则,命名函数是全局的。
1 // 全局的命名函数 2 function add(x, y) { 3 return x + y; 4 } 5 console.info(add(100, 200)); //300
匿名函数通常赋值给一个变量,再通过变量调用。
var func = function (x, y) { return x + y; } console.info(func(5, 2)); //7
匿名函数适用于以下这种 “立即执行的匿名函数” 的情况:
console.info( function (x, y) { return x + y; }(100, 200) //立即调用 );
命名函数可以先使用,再定义
console.info(sum(10, 10)); function sum(num1, num2) { return num1 + num2; }
匿名函数必须先定义,再使用
//console.info(sumFunc(10, 10)); //Uncaught TypeError: Property ‘sumFunc‘ of object [object Object] is not a function var sumFunc = function (num1, num2) { return num1 + num2; }; console.info(sumFunc(10, 10));
用return 生成返回值.如没有return ,则函数返回undefined
1 function func() { 2 } 3 console.info(func()); //undefined 4 function func2() { 5 return; //空的返回语句 6 } 7 console.info(func2()); //undefined
1 var func = function (x, y) { 2 var sum = x + y; 3 return { 4 value : sum 5 } 6 }
这么写没有问题: 调用 func(5,5) 返回的是 Object {value: 10}
然而:
1 var func = function (x, y) { 2 var sum = x + y; 3 return 4 { 5 value: sum 6 }; 7 } 8 console.info(func(5,5)); //undefined
1 function add(x, y) { 2 return x + y; 3 } 4 console.info(add(100, 200)); //300 5 var other = add; //other和add引用同一函数对象 6 console.info(other(300, 400)); //700 7 console.info(typeof other); //function 8 console.info(add === other); //true
1 function outerFunc(a, b) { 2 function innerFunc(x) { 3 return x * x; 4 } 5 return Math.sqrt(innerFunc(a) + innerFunc(b)); 6 } 7 console.info(outerFunc(3, 4)); //5
1 var globalStr = ‘globalStr‘; 2 function outerFunc2(argu) { 3 var localVar = 100; 4 function innerFunc2() { 5 localVar++; 6 console.info(argu + ":" + localVar + ":" + globalStr); 7 } 8 innerFunc2(); //hello:101:globalStr 9 } 10 outerFunc2("hello");
因为函数是对象,所以可以作为返回值。
1 function outerFunc(x) { 2 var y = 100; 3 return function innerFunc() { 4 console.info(x + y); 5 } 6 } 7 outerFunc(10)(); //110
标签:
原文地址:http://www.cnblogs.com/xiaoguanqiu/p/4635344.html