• JS代码整洁随笔


    // 之前都是这么写:使用undefined和null来检测一个属性是否存在
    if (obj['name'] !== undefined) {
        console.log('name属性存在'); // 若obj.name为undefined时则会导致判断出错
    }
    
    if (obj['name'] !== null) {
        console.log('name属性存在'); // 若obj.name为null时则会导致判断出错
    }
    
    // 推荐的写法:使用in运算符来检测对象属性是否存在,使用hasOwnProperty方法来检测不包含原型链上的对象属性是否存在
    if ('name' in obj) {
        console.log('name属性存在');
    }
    
    if (obj.hasOwnProperty('name')) {
        console.log('name属性存在');
    }
    --------------------------------------------------------------------------------------------------------------------------------------------------------------------
    --------------------------------------------------------------------------------------------------------------------------------------------------------------------
     
    // 不推荐的写法:==和!=比较时会进行类型转换,应尽量避免使用
    var num = 123;
    
    if (num == '123') {
        console.log(num);
    } else if (num != '321') {
        console.log('321');
    }
    
    // 推荐的写法:使用===和!==来进行比较
    var num = 123;
    
    if (num === '123') {
        console.log(num);
    } else if (num !== '321') {
        console.log('321');
    }
    --------------------------------------------------------------------------------------------------------------------------------------------------------------------
    --------------------------------------------------------------------------------------------------------------------------------------------------------------------

    // 不推荐的写法:用typeof来判断构造函数创建的对象
    var str = new String('劳卜'); 
    
    console.log(typeof str); // 'object'
    
    // 推荐的写法:用instanceof来判断构造函数创建的对象
    var str = new String('劳卜'); 
    
    console.log(str instanceof String); // true
     
  • 相关阅读:
    迈瑞医疗招聘-软件测试工程师
    软件自动化测试开发-3期开班啦
    luogu P2744 [USACO5.3]量取牛奶Milk Measuring
    luogu P2515 [HAOI2010]软件安装
    luogu P2423 双塔
    luogu P1651 塔
    luogu P1489 猫狗大战
    luogu P3092 [USACO13NOV]没有找零No Change
    luogu P3800 Power收集
    luogu P2949 [USACO09OPEN]工作调度Work Scheduling
  • 原文地址:https://www.cnblogs.com/chuanqiMa/p/6496495.html
Copyright © 2020-2023  润新知