18个编写 JavaScript 好习惯!

更新日期: 2020-10-22阅读: 1.5k标签: 优化

在我多年的编程生涯中,我会优先考虑编写代码的方式,不仅是为了让代码更简洁,还因为它有助于提高编码效率,使编写代码的速度更快。

写1000行代码和写300行代码是不一样的,这对我们正在做的程序或脚本有很大的帮助。编程时必须非常小心,因为在大型项目中,脏代码可能是一个严重的问题。

许多程序员批评 JS 语言没有像Java或c++那样的标准工作方式,但事实是JavaScript是目前使用的最好的语言之一,其中一些是Facebook和Netflix。像react这样的库提高了前端性能,至于后端,nextJs用于提高速度,这些组合让当今的程序员抓狂。

ECMAScript v6(缩写为ES6或ES2015)是JavaScript自2015年6月以来一直遵循的标准。

通过学习以下技巧,我们能够改善编写代码的方式。 花点时间在控制台上练习,学习好。

开始吧~

1.常量使用const代替var

常量是永远不变的变量,这样声明变量可以确保它们永远不变。

/* 旧方法 */
var i = 1;

/* 正确方式 */
const i = 1;

2. 使用let替换变量,而不是var

let语句声明了一个具有块作用域的局部作用域变量

/* 不适当的*/
var myVal = 1;
for (var i; i < 10; i++){
  myVal = 1 + i;
}

/* 正确方式*/
let myVal = 1;
for (let i; i < 10; i++){
  myVal += i
}

3.声明对象

用快捷方式声明对象

/* 
  旧方法
  The Object() class makes an unnecessary function call
*/

const myObject = new Object();
/* 正确方式*/
const myObject = {};

5.连接字符串

/* 旧方法 */
const myStringToAdd = "world";
const myString = "hello " + myStringToAdd;


/* 正确方式*/
const myStringToAdd = "world";
const myString = `hello ${myStringToAdd}`;

6. 使用对象方法简写

/* 不适当 */
const customObject = {
  val: 1,
  addVal: function () {
   return customObject.val + 1;
  }
}

/* 正确方式*/
const customObject = {
  val: 1,
  addVal(){
    return customObject.val++
  }
}**加粗文字**

7.创建对象的值

/* 旧方法*/
const value = 1;
const myObject = {
  value: value
}
/* 正确方式*/
const value = 1;
const myObject = {
  value
}

8. 给对象赋值

/* 旧方法 */
const object1 = { val: 1, b: 2 };
let object2 = { d: 3, z: 4 };
object2.val = object1.val;
object2.b = object1.b;

/* 正确方式 */
const object1 = { val: 1, b: 2 };
const object2 = { ...object1, d: 3, z: 4 }

9. 给数组赋值

/* 不适当*/
const myArray = [];
myArray[myArray.length] = "hello world";


/* 正确方式 */
const myArray = [];
myArray.push('Hello world');

10. 连接数组

/* 不适当*/
const array1 = [1,2,3,4];
const array2 = [5,6,7,8];
const array3 = array1.concat(array2);


/* 正确方式 */
const array1 = [1,2,3,4];
const array2 = [5,6,7,8];
const array3 = [...array1, ...array2]

11.获取对象的多个属性

/* 不适当*/
function getFullName(client){
  return `${client.name} ${client.last_name}`;
}

/* 正确方式 */
function getFullName({name, last_name}){
  return `${name} ${last_name}`;
}

12.从对象获取值

/* 不适当*/
const object1 = { a: 1 , b: 2 };
const a = object1.a;
const b = object1.b;

/* 正确方式 */
const object1 = { a: 1 , b: 2 };
const { a, b } = object1;

13. 创建函数

/* 老办法,但很好 */
function myFunc() {}

/* 很好*/
const myFunc = function() {}

/* 最好 */
const myFunct = () => {}

// 重要说明:在某些情况下,建议不要将这些函数与箭头一起使用,以避免读取错误

14.默认值

/* 不适当*/
const myFunct = (a, b) => {
  if (!a) a = 1;
  if (!b) b = 1;
  return { a, b };
}

/* 正确方式 */
const myFunct = (a = 1, b = 1) => {
  return { a, b };
}

15. 使用reduce代替forEach和for来求和

/* 不适当*/
const values = [1, 2, 3, 4, 5];
let total = 0;
values.forEach( (n) => { total += n})

/* 不适当*/
const values = [1, 2, 3, 4, 5];
let total = 0;
for (let i; i < values.length; i++){
  total += values[i];
}

/* 正确方式 */
const values = [1, 2, 3, 4, 5];
const total = values.reduce((total, num) => total + num);

16. 是否存在数组中

/* 不适当*/
const myArray = [{a: 1}, {a: 2}, {a: 3}];
let exist = false;
myArray.forEach( item => {
 if (item.a === 2) exist = true
})

/* 正确方式 */
const myArray = [{a: 1}, {a: 2}, {a: 3}];
const exist = myArray.some( item => item.a == 2)

17.布尔值的快捷方式

/* 不适当*/
const a = 5;
let b;
if (a === 5){
  b = 3;
} else {
  b = 2;
}

/* 正确方式 */
const a = 5;
const b = a === 5 ? 3 : 2;

总结

回顾这篇文章,加以练习并学会如何以一种更干净的方式工作,提高处理速度。


链接: https://fly63.com/article/detial/10096

js中for循环优化总结_如何提高程序的执行效率

在程序开发中,经常会使用到for循环的,但是很多人写的for循环效率都是比较低的,下面就举例说明,并总结优化for循环的方法,来提高我们程序的执行效率。

网站打开速度优化_如何提高网页访问速度技巧方法总结

网站的加载速度不仅影响着用户体验,也会影响搜索引擎的排名,在百度推出“闪电算法”以来,将网站首屏打开速度被列入优化排名行列,作为前端开发的我们需要如果来优化网站的打开速度呢?下面就整理挖掘出很多细节上可以提升性能的东西分享给大家

JS性能优化之文档片段createDocumentFragment

DocumentFragments是DOM节点。它们不是主DOM树的一部分。通常的用例是创建文档片段,将元素附加到文档片段,然后将文档片段附加到DOM树。在DOM树中,文档片段被其所有的子元素所代替。因为文档片段存在于内存中,并不在DOM树中

深入浅出代码优化﹣if/else

对于代码裡面的 if else,我们可以使用逻辑判断式,或更好的三元判断式来优化代码。除了可以降低维护项目的成本之外,还可以提升代码可读性。就让我们从最简单的 if else 例子开始吧。

微信小程序性能优化入门指南

小程序从发布到现在也已经有将近两年的时间,越来越来多的公司开始重视小程序生态带来的流量,今年也由于小程序平台对外能力的越来越多的开放以及小程序平台的自身优化,越来越多的开发者也自主的投入到小程序的开发当中

网络串流播放_HTML5如何优化视频文件以便在网络上更快地串流播放

无论你正在将 GIF 动图转换为 MP4 视频,还是手头已经有一大堆 MP4 视频,你都可以优化文件结构,以使得这些视频更快地加载和播放。通过重组 atoms 将 moov 放到文件开头,浏览器可以避免发送额外的 HTTP range request 请求来搜寻和定位 moovatom

​web项目优化_Web 服务器性能与站点访问性能优化

要优化 Web 服务器的性能,我们先来看看 Web 服务器在 web 页面处理上的步骤:Web 浏览器向一个特定的服务器发出 Web 页面请求; Web 服务器接收到 web 页面请求后,寻找所请求的 web 页面,并将所请求的 Web 页面传送给 Web 浏览器; 显示出来

前端性能优化之重排和重绘

浏览器下载完页面所有的资源后,就要开始构建DOM树,于此同时还会构建渲染树(Render Tree)。(其实在构建渲染树之前,和DOM树同期会构建Style Tree。DOM树与Style Tree合并为渲染树)

微信小程序代码优化总汇

写篇文章的目的,是以开放小程序代码的层面的优化。包括:条件判断将wx:if换成了hidden 、页面跳转请销毁之前使用的资源、列表的局部更新、小程序中多张图片懒加载方案、Input状态下隐藏input,应预留出键盘收起的时间

我是如何将页面加载时间从6S降到2S的?

生活在信息爆炸的今天,我们每天不得不面对和过滤海量的信息--无疑是焦躁和浮动的,这就意味着用户对你站点投入的时间可能是及其吝啬的(当然有一些刚需站点除外)。如何给用户提供迅速的响应就显得十分重要了

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!