(1)箭头函数的定义
基本语法:
let fn=function(){
console.log(11);
}
fn()
function fn1(){
console.log(222);
};
fn1()
let fn2=()=>{
console.log(3333);
};
fn2();
箭头函数只有一个参数时,可以不用括号()
let fn=a=>{
console.log(a);
};
fn(6)
相反,如果使用多个参数,就必须使用括号()
let fn1=(a,b,c)=>{
console.log(a,b,c);
};
fn1(10,20,30);
如果箭头函数的执行体只有一个表达式 就是返回值 那么可以省略大括号。
let fn=(a,b)=>a+b;
let num= fn(10,20);
console.log(num);
当箭头函数要返回对象的时候,为了区分于代码块,要用 () 将对象包裹起来。
let f = (a, b) => ({ id: a, name: b });
let obj = f(11, "小明");
console.log(obj);
箭头函数里面的this不是箭头函数的调用者,而是箭头函数的外层作用域。
let fn=(a,b)=>{
console.log(this);
return a+b
};
let obj={name:"小明",fn}
let num=obj.fn(10,20);
console.log(num);
let fn1=function(a,b){
console.log(this);
return a+b
};
let obj1={name:"小明",fn}
let num1=obj.fn(10,20);
console.log(num);
箭头函数不可以作为构造函数,也就是不能使用 new 命令,否则会报错
let fn=function(){
console.log(this);
};
new fn();
let fn1=()=>{
console.log(this);
};
new fn1()
(2)使用箭头函数的注意点
(1)箭头函数没有自己的this对象。 (2)不可以当作构造函数,也就是说,不可以对箭头函数使用new命令,否则会抛出一个错误。 (3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。 (4)对象里面的方法,尽可能不要使用箭头函数 (5)箭头函数里面的this总是指向最靠近的function 内部的this;
|