【前端学习】ES6语法 函数写法优化

函数默认值设置

非ES6语法

// 参数b 可为空的情况下给默认值1
function func1(a,b){
    if(!b){
        b=1;
    }
    return a+b;
}
//或者
function func1(a,b){
    b=b||1;
    return a+b;
}

ES6语法

可在方法入口参数定义上加 = 默认值,如果参数为空,则等于默认值。

function func1(a,b=1){
    return a+b;
}

lambda表达式(箭头函数)

非ES6 lambda语法

//返回运算结果
function func1(a,b){
    if(!b){
        b=1;
    }
    return a+b;
}
//执行方法
function func2(a,b){
    if(!b){
        b=1;
    }
    console.log(a+b);
}

ES6 lambda语法

//返回运算结果
let func1=(a,b=1)=>{return a+b;};
//执行方法
let func2=(a,b=1)=>console.log(a+b);

ES6 lambda语法+解构表达式

//定义 user 对象
let user={
        name:"艾伦·耶格尔",
        age:16
    };

//不使用 lambda+解构表达式 输出name,age信息
function print(user){
    return user.name+","+user.age;
}
console.log(print(user));
//艾伦·耶格尔,16


//使用 lambda 输出name,age信息
let print=(user)=>{ return user.name+","+user.age;};
console.log(print(user));
//艾伦·耶格尔,16


//使用 lambda+解构表达式 输出name,age信息
let print=({name,age})=>{ return name+","+age;};
console.log(print(user));
//艾伦·耶格尔,16

对象函数

非ES6语法

let obj={
        para1:"1",
        para2:"2",
        toString:function(){
            return this.para1+this.para2;
        }
    };
console.log(obj.toString());
//12

ES6语法

不再必须  对象方法名 : function(){}的格式进行定义对象方法,直接 对象方法名(){}进行定义即可。

let obj={
        para1:"1",
        para2:"2",
        toString(){
            return this,para1+this.para2;
        }
    };
console.log(obj.toString());
//12

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值