js小技巧

1、用??代替||,用于判断运算符左侧的值为null或undefined时,才返回右侧的值

??运算符是ES2020引入,也被称为null运算符

它的行为类似||,但是更严

||运算符是左边是空字符串或false0false值,都会返回后侧的值。而??必须运算符左侧的值为nullundefined时,才会返回右侧的值,因此0||1的结果是1,0??1的结果为0.

2、使用?.简化&&和三元运算符

?.也是ES2020引入,有人称为链判断运算符。

?.直接在链式调用的时候判断,判断左侧的对象是否为nullundefined,如果是,就不再往下运算,返回undefined,如果不是,则返回右侧的值。

var street = user.address && user.address.street;

// 简化
var street = user.address?.street;

var fooInput = myForm.querySelector('input[name=foo]');
var fooValue = fooInput ? fooInput.value : undefined

// 简化
var fooInput = myForm.querySelector('input[name=foo]')?.value;

3、使用String.prototype.replaceAll()简化replace一次性替换所有子字符串

String.prototype.replaceAll()用法与String.prototype.replace()类似

但是replace仅替换第一次出现的子字符串,而replaceAll会替换所有

// 以前
console.log('aaa'.replace(/a/g,'A'))
// 简化后
console.log('aaa'.replaceAll('a','A'))

4、使用Array.prototype.at()简化arr.length

Array.prototype.at()接收一个正整数或者负整数作为参数,表示获取指定位置的成员。

参数正数就表示顺数第几个,负数表示倒数第几个,这可以很方便的获取摸个数组末尾的元素

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值