Es6 函数的扩展

1.函数默认参数

在ES6之前函数不能为参数指定默认值,只能采用变通的方法

例如:

function(x,y){

      if(!y){

               y = "hello"

      }

}

ES6里面函数定义:

function(x,y=”hello“){ ...............}

function foo(x=1,y=3){     console.log(x,y)        }

foo(undefined,null)     //输出 1,null 

 注意:如果传入undefined将会触发该参数等于默认值,null则触发不了;

          指定了默认值以后函数的length属性将返回没有指定默认值的参数个数,例如:foo.length = 0。

2.默认参数的应用

利用默认参数可以指定某大哥参宿不可以省略,如果省略了就跑出错误;

3.函数的reset

参数使用了扩展运算符(...),用于获取函数的多余参数,reset参数后不能再有其他参数,但之前可以有

function(...values)

          for(var val of values){

                      sum += val;

            }

}

其中使用了ES6的for ......of.......循环

4.扩展运算符

1)...[2,3,4] = '2,3,4'

求数组最大值  Math.max(...[2,3,4,5])

2)数组合并arr1.concat(arr2) = [...arr1,...arr2]

3)与结构赋值结合

const [fist,...last] = [1,2,3,4,5]   //first =1;last = [2,3,4,5]

4)扩展运算符还可以将字符串转换成真正的数组 [...“hello” ] = ['h','e','l','l','o']

5)任何类似数组对象都可以用扩展字符转化为真正的数组[...nodeList] ,ES5里需要用Array.prototype.slice.call(nodeList)

5.name属性

            函数的name属性返回函数名

6.箭头函数

 v=>v                   等价于      function(v){return v}

(x,y)=> x+y       等价于 function(x,y){return x+y}

注意:1)函数体内的this对象就是定义时所在的对象,不是使用时所在对象(可以理解为箭头函数里面没有this指针)

           2)  不可以当做构造函数,

           3)不可以使用arguments,

           4)  不可以适应yield命令,因此箭头函数不能用作Generator函数;

            5) 不能使用bind , call , apply方法改变this指向;

例如:function foo(){

                   setTimeOut( () => {  

                           console.log(this.id)

                     },1000)

             }

             foo.call({'id':10)    //10

7.函数绑定::

    


双冒号左边是对象,右边是函数;

8.尾调用优化

function  f(x){

          return g(x);

}

尾调用是由于函数在调用时会生成一个调用帧,用来保存变量位置等信息;如果函数A的内部调用函数B,那么在A的调用帧的上部就会有B的调用帧。而尾部调用由于是函数的最后一步操作,所以没必要再保留外层函数的调用帧,这大大节省了内存空间。

9.尾递归和柯里化

柯里化意思是将多参数的函数转化成但参数的形式。

尾递归尾调用自身即为尾递归。

作者:Ls

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容

  • 函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数l...
    陈老板_阅读 449评论 0 1
  • 函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数l...
    呼呼哥阅读 3,380评论 0 1
  • 前面的话 函数是所有编程语言的重要组成部分,在ES6出现前,JS的函数语法一直没有太大的变化,从而遗留了很多问题,...
    CodeMT阅读 822评论 0 1
  • 01 实习结束便又重新回到了学校 回来那天恰好是开学第一天 学校人很多 看到的都是一张张朝气蓬勃的脸 我旁边的妹子...
    小阿姨吖阅读 111评论 0 0
  • 2018年9月3 日 ㈠战痘成功(不吃辣)【18/90】 ㈡早睡早起(起/5:30睡/23:00)【18/90】 ...
    毛竹_30e5阅读 103评论 0 0