函数是JS的核心概念,主要用来封装语句,需要注意一下
细碎的小点
- return语句,一旦return,后续的语句不会继续执行了,不加return的话,函数默认的返回值是undefined
有关参数的理解
函数不在意它本身到底接收多少参数,不关心最后会使用多少参数。因为函数只会接收一个数组,函数可以通过arguments对象来访问这个参数数组。关于这个数组,我现在知道这些:
arguments对象
这个数组其实是个对象,如下:
javascript
var a = function () {var b= 1; var c = 0} //a是一个函数
typeof a.arguments // Object
但是为什么又说它是数组呢,因为它本身很数组很像,可以通过方括号加数字的方法来访问具体的参数,同时还有数组对象有的length属性。一个有趣的例子:
```javascript
function a (){
console.log("hello" + arguments[0] + arguments[1]);
}
a("hao","xiang"); //hellohaoxiang
这样子依然是有效的,在函数执行的时候,通过arguments对象的length属性可以知道被传递的参数个数,还有个更有趣的例子,是关于arguments的同步性的:
function doAdd(num1,num2){
arguments[1]=10;
alert(arguments[0] + num2);
}
doAdd(1,1); //11,arguments[1]和num2是同步的
传递参数
参数就是局部变量,对于函数来说,传递参数是按值的,基本类型的很好理解,相当于变量的复制。
对于引用类型来说,还需要留意到此时依然是按值传递的,这个值依然是指引用的内存地址值。
证明方法,需要先创建一个对象,传递函数中,此时在函数内部修改对象的属性,此时内外是一致的,因为他们是一种的一个对象
但是此时如果将参数重新初始化为两一个对象,那么也就是说此时参数已经指向另一个变量了,和之前的一切无关。
再探函数内部的属性
arguments属性有一个叫做callee的指针,这个指针指向拥有这个arguments对象的函数。主要用来接触耦合,需要明确一下书上关于递归算法的例子
function fac (num) {
switch (num){
case 1 :
return 1;
default: return num * arguments.callee(num-1);
}
}
函数的另外一个内部属性是this对象
this引用的是函数据以执行的环境对象
具体的理解:
this是包含它的函数作为方法被调用是所属的对象 = 包含它的函数 + 作为方法被调用时 + 所属的对象
重点内容——函数的属性和方法
apply(),这个方法表示在特定的作用域内调用函数
与call()的区别在于call在使用时必须指定参数
bind()方法,这个方法可以用来创建一个新的实例,实例的this值会被绑定到传给bind()的值上