Js代码高效技巧

1、 !(!!)和~符号的使用

//传统方式
let str = 'javascript'
if(str.indexOf('java')>-1){
  //执行代码
}
//简写方式
if(!!~str.indexOf('java')){
//执行代码 (注意此方式在数据量大的情况下有性能问题)
}

说明:!!一般用来将后面的表达式强制转换为布尔类型的数据(boolean),也就是只能是true或者false;
js中在变量名前加"~" 是位运算NOT,按位取反。

2、||、&& 短路运算符

//举例1:
let flag = true
function test(){
  //执行代码
}
if(flag){
   test()
}
//简写
flag &&  test()

//举例2
let a=100,b;
if(a>50){
  b=100
}else{
  b=5
}
等价于: b = a > 50 && 100 || 5
//可以把 && 看做是找假运算。找到假,直接停止,将假返回;找到真,则会继续找,直到找到假才停止,并将假返回。如果都为真,则返回最后一个真。
//可以把 || 看做是找真运算。找到真,直接停止,将真返回;找到假,则会继续找,直到找到真才停止,并将真返回。如果都为假,则返回最后一个假。

3、map,object代替if else

const status= 0
const statusText = 0
// 0 已下单 ,未支付 , 1已支付, 2已发货, 3已完成
if (statusCode === 0) {
  statusText = '已下单,未支付'
} else if (statusCode === 1) {
  statusText = '已支付'
} else if (statusCode === 2) {
  statusText = '已发货'
}else if (statusCode === 3) {
  statusText = '已完成'
}
//更好的写法
const statusMap = new Map([
  [0, '已下单,未支付'],
  [1, '已支付'],
  [2, '已发货'],
  [3, '已完成'],
])
statusText  = statusMap.get(status)

4、高阶函数

高阶函数就是一个将函数作为参数或者返回值的函数。js内置的函数reduce,map,filter就是高阶函数

  const arr = [{
        userName: '张三',
        sex: '男',
        code: 100
    },
    {
        userName: '张三',
        sex: '女',
        code: 80
    },
   {
        userName: '张三',
        sex: '女',
        code: 92
    },
    {
        userName: '李四',
        sex: '男',
        code: 95
    }//还有其他数据...
]
   // 要求找到数据中姓名张三
    const findPeople = name => o => o.userName === name
    arr.filter(findPeople('张三'))

使用高阶函数可以让代码复用性更好,也便于维护。配合es6的语法,可以让函数变得更简洁(当然写不好的化也变得难于阅读)。

5、合并数据

let arr1 = [1,2,3],arr2=[4,5,6]
如何得到[1,2,3,4,5,6]数组?
//方法1:arr1.concat(arr2)
//方法2:[...arr1,...arr2]
//方法3:arr1.push(...arr2), 此方式修改了arr1的长度,等价于:arr1.push.apply(arr1,arr2)

6、可选链操作符

可选链操作符( ?. )允许读取位于连接对象链深处的属性的值,而不必明确验证链中的每个引用是否有效。?. 操作符的功能类似于 . 链式操作符,不同之处在于,在引用为空(nullish ) (null 或者 undefined) 的情况下不会引起错误,该表达式短路返回值是 undefined。与函数调用一起使用时,如果给定的函数不存在,则返回 undefined。

let obj = {
    data: {
      name: "张三",
    },
  };
// 如果我们想取obj里data里的name字段,要对obj和data等字段做判空处理,不然代码就会报错
原始方法:const name = obj && obj.data &&  obj.data.name
改进:const name = obj?.data?.name;

7、空值合并操作符

空值合并操作符(??)是一个逻辑操作符,当左侧的操作数为 null 或者 undefined 时,返回其右侧操作数,否则返回左侧操作数。

//在处理输入框相关业务时,往往会判断输入框未输入值的场景。
if(value !== null && value !== undefined && value !== ''){
    //...
}
//使用空值合并操作符,如下
if((value??'') !== ''){
  //...
}

注意与 || 的区别。由于 || 是一个布尔逻辑运算符,左侧的操作数会被强制转换成布尔值用于求值。任何假值(0, '', NaN, null, undefined)都不会被返回。这导致如果你使用0,''或NaN作为有效值,就会出现不可预料的后果。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容