如果函数内有返回值
var fn = v => v + 1
返回值如果不是表达式(是对象),用()括号返回
var fn = v => ({ obj: v })
返回值如果不是表达式(也不是对象)方法体内按正常写
var fu = () => {
var a = 1;
var b = a+1;
return b;
}
this指向不同:
箭头函数的this指向继承自其上一层作用域的this,无法通过call和apply改变this指向。
箭头函数的this指向由函数定义位置所决定而不是函数调用位置决定
不能作为构造函数(不能new) ,也没有prototype属性
箭头函数本身是没有this的,他的this是从他作用域链的上一层继承来的,并且无法通过call和apply改变this指向
箭头函数的this,是看箭头函数定义位置所在的作用域,而不是函数调用的位置(也可以说继承上一级作用域的this)
function* fn(){
yeild 1;
yeild 2;
return 3;
}
var f = fn();
f.next();// Generator 函数调用
普通函数: 使用短路运算来给默认值
1.箭头函数使用默认值
function fn (x, y) {
y = y || 1
console.log('合计:'x + y)
}
//箭头函数
function fn (x, y = 1) {
console.log('合计:'x + y)
}
// 与解构赋值默认值配合使用
function fn1 ({x, y = 1}) {
console.log('合计:'x + y)
}
fn1({x: 1})
function fn (x, ...y) {
console.log(x)
console.log(y)
}
fn(1, 2, 3, 4)
function m1({x = 0, y = 0} = {}) {
return [x, y];
}
function m2({x, y} = { x: 0, y: 0 }) {
return [x, y];
}
console.log(m1())
console.log(m2())
console.log(m1({x: 3}))
console.log(m2({x: 3})) // 3, undefined
vue项目中的实际运用:点击按钮时,打开msgbox的窗口。在普通函数和this函数下不同写法
var name = 'window'
var obj = {
name: 'obj',
methods: () => {
console.log(this.name)
},
fn: function (cb) {
cb()
}
}
obj.fn1 = function () {
obj.fn(() => { console.log(this.name) })
}
var fn1 = obj.fn1
obj.methods() //箭头函数this取决于定义位置的作用域的this,定义在obj对象(而对象没有作用域),所以只能是window,所以打印window
obj.fn(() => { console.log(this.name) })//箭头函数作为参数传入,定义在函数调用位置,还是在全局作用域,所以还是window
fn1() // 定义在obj.fn()中定义的,而obj.fn()是指向window
obj.fn1() //obj
var fn = function () {
return () => { console.log(this.name) }
}
var obj1 = {
name: '张三'
}
var obj2 = {
name: '李四'
}
var name = '王五'
obj1.fn = fn
obj2.fn = fn
obj1.fn()() //obj1.fn()先执行,再将执行结果作为方法名进行执行
obj2.fn()()
fn()()
var user = {
name: '张三',
fn: function () {
var obj = {
name: '李四'
}
var f = () => this.name
// 箭头函数this取决于定义位置所在的位置,即和fn的this指向保持一直
return f.call(obj)
}
}
var res = user.fn(); //张三