美文网首页
再探JS函数

再探JS函数

作者: 郝翔 | 来源:发表于2016-06-09 18:41 被阅读13次

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

相关文章

  • 再探JS函数

    函数是JS的核心概念,主要用来封装语句,需要注意一下 细碎的小点 return语句,一旦return,后续的语句不...

  • 代码规范-1

    JS/TS部分: 函数与函数之间空一行 js/ts 函数的大括号与函数名再同一行 注意行末的分号4 注意空格 函数...

  • JavaScript 05 函数

    js函数的概念和作用,js函数的定义,js函数的调用,js事件驱动的概念,js函数的实参和形参,js的作用域,js...

  • js 深入

    * js语法* js的动态函数和匿名函数* js动态函数Functionnew Function();* 匿名函数...

  • 再探Swift函数的派发方式

    Swift 的函数是怎么派发的呢? 我没能找到一个很简明扼要的答案, 但这里有四个选择具体派发方式的因素存在: 声...

  • 再探JS中的Array类型

    Array类型 注意区分索引和项数的差别,数组的项数始终比索引大一,那么可以利用length属性为Array添加新...

  • Javascript 变量执行过程 和 数组 & 对象的区别

    变量提升 JS执行过程1. 先提升(先提升函数,再提升变量,如果名字一样,变量提升会覆盖函数提升)2. 再执行,如...

  • 2018-12-01

    js中括号操作属性 js函数 js换肤 变量和函数预解析 匿名函数 函数传参 函数return关键字 流程控制语句...

  • jQuery入口函数的作用以及jQuery入口函数和js入口函数

    jQuery的入口函数 js和JQuery入口函数的区别 JS入口函数和JQuery入口函数

  • js 闭包

    一、js 作用域 讲闭包首先就要理解 js 的作用域。再 ES5 中,js 有两种作用域,全局作用域和函数作用域(...

网友评论

      本文标题:再探JS函数

      本文链接:https://www.haomeiwen.com/subject/bdfsdttx.html