Js代码高效技巧

作者: _littleTank_ | 来源:发表于2021-10-16 12:35 被阅读0次

    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作为有效值,就会出现不可预料的后果。

    相关文章

      网友评论

        本文标题:Js代码高效技巧

        本文链接:https://www.haomeiwen.com/subject/upfsohtx.html