如何让你的JavaScript代码更优雅(上)

简介: 写了好多年的JavaScript代码,你的代码是不是可以更加优雅?下面整理了一些优化代码的建议,大家可以酌情做一下参考,希望能给到大家一些帮助。

1.推荐使用全等和不全等操作符


ECMAScript 提供两组操作符:相等和不相等(== 和 !=)——先转换再比较,全等和不全等(=== 和!==)——仅比较而不转换


除了在比较之前不转换操作数之外,全等和不全等操作符与相等和不相等操作符没有什么区别


如下所示:


var result1 = ("66" == 66);    //true,因为转换后相等 
var result2 = ("66" === 66);  //false,因为不同的数据类型不相等


要记住:null == undefined 会返回 true,因为它们是类似的值;但 null === undefined 会返 回 false,因为它们是不同类型的值。


由于相等和不相等操作符存在类型转换问题,而为了保持代码中数据类型的完整性,推荐使用全等和不全等操作符。如果变量的类型是已经确定了的,那么使用==是根本没必要的;如果类型不确定,应该手动做一下转换:


var code = "5";
if(parseInt(code) === 0){
}


2.不建议修改变量所保存值的类型


变量是松散类型的,所谓松散类型就是可以用来保存任何类型的数据。换句话说, 每个变量仅仅是一个用于保存值的占位符而已;如下代码:


var message = "hi"; 


像这样初始化变量并不会把它标记为字符串类型; 初始化的过程就是给变量赋一个值那么简单。因此,可以在修改变量值的同时修改值的类型:


var message = "hi"; 
message = 100;         // 有效,但不推荐 


这样给人的感觉就过于随意了,且可读性太差,同时,js引擎在进行编译的时候也需要额外的耗时,不利于性能。推荐的方式是在初始化变量的时候给变量一个默认值:


var message = "hi",
    found = false,     
    age = 29


3.避免延长作用域链


在两种情况下会发生作用域链的延长:


  • try-catch 语句的 catch 块;


  • with 语句


这两个语句都会在作用域链的前端添加一个变量对象。对 with 语句来说,会将指定的对象添加到 作用域链中。对 catch 语句来说,会创建一个新的变量对象,其中包含的是被抛出的错误对象的声明。


我们知道,标识符解析是沿着作用域链一级一级地搜索标识符的过程。搜索过程始终从作用域链的前端开始, 然后逐级地向后回溯,直至找到标识符为止,因此作用域链越长,查找越慢。


4.缓存变量


比如数组长度:


for (let j = 0; j < area.geo.length; j++) {
 }


应该写到一个变量里,避免每次循环都去查找这个对象且计算长度


let geoLength = area.geo.length
for (let j = 0; j < geoLength; j++) {
 }


另外,缓存变量可以进行dom的优化:


let odiv=document.getElementById('content');
//接下来是一些操作dom的代码。。。


这样避免了多次去查找dom元素,可以提高代码效率。


5.关于if语句


大多数编程语言中为常用的一个语句就是 if 语句,这里提三点建议:


(1)始终使用代码块


业界普遍推崇的佳实践是始终使用代码块,即使要执行的只有一行代码。因为这样可以消 除人们的误解,否则可能让人分不清在不同条件下要执行哪些语句。


if (i > 25)    
alert("Greater than 25.");             // 单行语句 
else {     
alert("Less than or equal to 25.");    // 代码块中的语句 
} 


(2)用三目运算符取代简单的 if-else


比如一个简单的函数:


lightBackground () {
      if(this.mode === 'dark'){
          return normal
      }else {
           return light
      }
    }


用三目运算符来写就不会显得很臃肿,给人的感觉很清晰


lightBackground () {
      return this.mode === 'dark' ? 'normal' : 'light'
    }


原来的五行代码现在需要一行就OK了,代码的执行效率也比之前的要高。


(3)优化嵌套的条件语句


比如有大量的if-else语句:


if (index === 0) {
       fn0();
      } else if (index === 1) {
        fn1();
      } else if (index === 2) {
        fn2();
      } else if (index === 3) {
        fn3();
      }


可以用switch语句来优化代码。从根本上讲,switch 语句就是为了让开发人员免于编写像上面这样的代码。


switch(index){
    case 0:
    fn0();
    break;
    case 1:
    fn(1);
    break;
    case 2:
    fn2();
    break;
    case 3:
    fn3();
    break;
    default:
    fn()
}


或者使用对象的方法替代:


let idxObj = {
    0: fn0,
    1: fn1,
    2: fn2,
    3: fn3,
    4: fn
}
if(num in idxObj){
    idxObj[num]()
}


相关文章
|
3月前
|
JavaScript
短小精悍的js代码
【10月更文挑战第17天】
144 58
|
2天前
|
人工智能 程序员 UED
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
3月前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。
【10月更文挑战第7天】随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 来检查代码规范并自动格式化 Vue.js 代码。通过安装和配置这两个工具,可以确保代码风格一致,提升团队协作效率和代码质量。
305 2
|
3月前
|
JavaScript 前端开发 内存技术
js文件的入口代码及需要入口代码的原因
js文件的入口代码及需要入口代码的原因
54 0
|
3天前
|
人工智能 JavaScript 前端开发
一段 JavaScript 代码,集成网站AI语音助手
根据本教程,只需通过白屏化的界面操作,即可快速构建一个专属的AI智能体。
|
1月前
|
JavaScript 前端开发 测试技术
在 golang 中执行 javascript 代码的方案详解
本文介绍了在 Golang 中执行 JavaScript 代码的四种方法:使用 `otto` 和 `goja` 嵌入式 JavaScript 引擎、通过 `os/exec` 调用 Node.js 外部进程以及使用 WebView 嵌入浏览器。每种方法都有其适用场景,如嵌入简单脚本、运行复杂 Node.js 脚本或在桌面应用中显示 Web 内容。
104 15
在 golang 中执行 javascript 代码的方案详解
|
2月前
|
JavaScript
原生js炫酷随机抽奖中奖效果代码
原生js随机抽奖是一个炫酷的根据数据随机抽奖的代码,该网页可进行随机抽取一个数据,页面动画高科技、炫酷感觉的随机抽奖效果,简单好用,欢迎下载!
69 3
|
2月前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
662 4
|
2月前
|
JSON 移动开发 数据格式
html5+css3+js移动端带歌词音乐播放器代码
音乐播放器特效是一款html5+css3+js制作的手机移动端音乐播放器代码,带歌词显示。包括支持单曲循环,歌词显示,歌曲搜索,音量控制,列表循环等功能。利用json获取音乐歌单和歌词,基于html5 audio属性手机音乐播放器代码。
157 6