美文网首页
箭头函数笔记

箭头函数笔记

作者: _claus | 来源:发表于2018-03-24 20:22 被阅读0次

回顾ES3,5

// 具名函数
function xxx(v1,v2){
    console.log('函数体')
    return v1 + v2
}
// 匿名函数
let fn = function (v1,v2){
    console.log(‘函数体’)
    return v1 + v2
}
匿名函数必须赋值才可以使用。或者使用立即执行函数的方式。

上面代码中示例匿名函数,可以拆分成三步看。

  1. 声明一个变量let fn

  2. 声明一个匿名函数。

  3. 将匿名函数作为值赋给变量fn。

然后再来看看ES6最新的箭头函数

箭头函数只能做赋值,不能当作声明
let fn = (v1,v2) =>{
    console.log('函数体')
    return v1+v2
}

以上就等价于上面的匿名函数
  • 如果一个函数只有一个参数
let fn = v1 => {
    console.log('函数体')
    return v1 
}
fn(11)  //  '函数体'  11

// 还是上面的例子,做个小改动。
let fn = v1 => {
    console.log('函数体')
}
fn(1)  // '函数体' undefined
// 并没有写入return语句,那么js就会默认帮你添加return undefined
  • 如果你的函数体只有一句话,你可以不需要写花括号和return。
 // 示例 let fn1 = (v1,v2) => { return v1+v2 }
// 可以写作如下方式
let fn  = (v1,v2) => v1+v2
// 省略花括号以及return。当你这样写,实际上就默认return v1+v2所以连return 都可以省略掉。但是如果你习惯加花括号,你就必须加上前面的return语句。
  • 最简化的箭头函数
let fn = v1 => v1 * 2

fn(2)  // 4

箭头函数,传统函数,this

this是call 的第一个参数,this是call 的第一个参数,this是call 的第一个参数!!!

如何理解这句话。
看个例子:

var content = {
    el : 'web',
    init : function (){
        console.log(this.el)  
    }
}
// content.init()  等价于
content.init.call(content)  // this就指的是content。

ES3于ES6都支持this。
但是在ES6中,箭头函数的出现,弱化了this的用法。

关于传统函数和箭头函数。

function fn(){
    console.log(this)
}
// 如果直接调用,fn()那么,会直接返回window。
fn.call({name : 'claus'})  // this指针指向了这个对象。 {name : 'claus'}所以打印的结果就是该对象。


let fn1 = () => {
    console.log(this)
}
fn1.call({name : 'claus'})  // window...  并没有接受this参数。
let obj = {
    name : 'claus',
    sayName : (that) => {
        console.log(that.name)
// 如果你直接打印this.name  箭头函数会报错,所以需要如果需要用this 可以传入一个形参来代替this,并且在外面调用的时候将这个this的指针传入即可。
    }
}
obj.sayName(obj)

这就是箭头函数的好处,没有潜规则(隐藏的this是作为函数的第一个参数),之前的function函数参数是会有一个this参数的。只不过讲this参数隐藏了而已。

箭头函数的优点。
亮出代码吧。

let arr = [1,2,3,4,5]

let arr2 = []

for (let i = 0; i < arr.length;i++){
    arr2.push(arr[i] * arr[i]) 
}
console.log(arr2)  // [1, 4, 9, 16, 25]

// 继续简化如下
let arr = [1,2,3,4,5]

let arr2 = arr.map(function (num){
    return num * num
})
console.log(arr2)

// 箭头函数  
let arr = [1,2,3,4,5]
let arr2 = arr.map(num => num * num)
console.log(arr2)  //  [1, 4, 9, 16, 25]
// 并且这种方式是可以叠加的。
let arr2 = arr.map(num => num * num)
              .map(num => num + 1)
              .map(num => num  + num)
  1. 箭头函数让this变的可以理解。

  2. 箭头函数让代码更简洁。

相关文章

  • 箭头函数 笔记

    为什么引入箭头函数 this 太难用了 this是call()的第一个参数既然是参数 它是什么就得看(functi...

  • ES6~箭头函数

    什么是箭头函数 单表达式箭头函数 相当于 多表达式箭头函数 箭头函数相当于匿名函数,并且简化了函数定义。箭头函数有...

  • 箭头函数和立即执行函数

    箭头函数 箭头函数和普通函数有什么区别?如果把箭头函数转换为不用箭头函数的形式,如何转换主要是this的差别,箭头...

  • 学习 ES 6 箭头函数

    箭头函数的用法 ES6 允许使用“箭头”(=>)定义函数。 箭头函数的一个用处是简化回调函数。 箭头函数 this...

  • 箭头函数

    箭头函数 箭头函数能让this的指向固定化 分析:1)第一个setInterval()中使用了箭头函数,箭头函数使...

  • TS  笔记this

    this 箭头函数在箭头函数创建的地方获得this;非箭头函数,在调用函数的地方获得this如图

  • 箭头函数和数组

    箭头函数&数组 箭头函数 特点: 没有 this 没有 arguments 没有prototype在箭头函数中使用...

  • 箭头函数

    箭头函数 为什么使用箭头函数

  • 箭头函数中this的指向

    箭头函数在平时开发中用着非常爽,箭头函数有什么特点呢 箭头函数不能够当做构造函数使用 箭头函数没有argument...

  • js学习笔记4(函数)

    1.箭头函数 ES6新增属性。箭头函数特别适合嵌入函数的场景。 箭头函数虽然语法简介,但是很多场合不适用。箭头函数...

网友评论

      本文标题:箭头函数笔记

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