再探JS函数

函数是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()的值上

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,270评论 0 4
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 在js中,函数本身属于对象的一种,因此可以定义、赋值,作为对象的属性或者成为其他函数的参数。函数名只是函数这个对象...
    bjhu电net阅读 553评论 0 5
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,854评论 2 17
  • 偶然的机会看到简书,当时不知道简书,二了吧唧的问了度娘,然后就下载了app,就想知道是什么软件,根本没想其他。可是...
    马何木子阅读 109评论 0 0