如何在JavaScript中正确处理变量
变量无处不在。即便我们写一个小函数或一个小工具,也要声明、赋值和读取变量。增强对变量的重视,可以提高代码的可读性和可维护性。
1.建议使用const,要么使用let
用const或let声明自己的JavaScript变量。两者之间的主要区别是const变量在声明时需要初始化,并且一旦初始化就无法再重新赋值。
//const需要初始化 constpi=3.14; //const不能被重新赋值 pi=4.89; //throws"TypeError:Assignmenttoconstantvariable"
let声明不需要对值初始化,可以多次重新赋值。
//let要不要初始化随你 letresult; //let可被重新赋值 result=14; result=result*2;
const是一次性分配变量。因为你知道const变量不会被修改,所以与let相比,对const变量的推测比较容易。
声明变量时优先使用const,然后是let。
假设你正在review一个函数,并看到一个constresult=...声明:
functionmyBigFunction(param1,param2){ /*一写代码...*/ constresult=otherFunction(param1); /*一些代码...*/ returnsomething; }
虽然不知道myBigFunction()中做了些什么,但是我们可以得出结论,result变量是只读的。
在其他情况下,如果必须在代码执行过程中多次重新对变量赋值,那就用let。
2.使变量的作用域最小化
变量位于创建它的作用域中。代码块和函数体为const和let变量创建作用域。
把变量保持在最小作用域中是提高可读性的一个好习惯。
例如下面的二分查找算法的实现:
functionbinarySearch(array,search){ letmiddle;letmiddleItem;letleft=0; letright=array.length-1; while(left<=right){ middle=Math.floor((left+right)/2); middleItem=array[middle]; if(middleItem===search){ returntrue; } if(middleItemtrue binarySearch([2,5,7,9],1);//=>false
变量middle和middleItem是在函数的开头声明的,所以这些变量在binarySearch()函数的整个作用域内可用。变量middle用来保存二叉搜索的中间索引,而变量middleItem保存中间的搜索项。
但是middle和middleItem变量只用在while循环中。那为什么不直接在while代码块中声明这些变量呢?
functionbinarySearch(array,search){ letleft=0; letright=array.length-1; while(left<=right){ constmiddle=Math.floor((left+right)/2); constmiddleItem=array[middle]; if(middleItem===search){ returntrue; } if(middleItem现在middle和middleItem只存在于使用变量的作用域内。他们的生命周期极短,所以更容易推断它们的用途。
3.易于使用
我总是习惯于在函数开始的时候去声明所有变量,尤其是在写一些比较大的函数时。但是这样做会使我在函数中使用变量的意图变得非常混乱。
所以应该在变量声明时应该尽可能靠的近使用位置。这样你就不必去猜:哦,这里声明了变量,但是…它被用在什么地方呢?
假设有一个函数,在函数有包含很多语句。你可以在函数的开头声明并初始化变量result,但是只在return语句中使用了result:
functionmyBigFunction(param1,param2){ constresult=otherFunction(param1); letsomething; /* *一些代码... */ returnsomething+result;}问题在于result变量在开头声明,却只在结尾用到。我们并没有充分的理由在开始的时后就声明这个变量。
所以为了更好地理解result变量的功能和作用,要始终使变量声明尽可能的靠近使用它位置。
如果把代码改成这样:
functionmyBigFunction(param1,param2){ letsomething; /* *一些代码... */ constresult=otherFunction(param1); returnsomething+result;}现在是不是就清晰多了。
4.合理的命名
你可能已经知道了很多关于变量命名的知识,所以在这里不会展开说明。不过在众多的命名规则中,我总结出了两个重要的原则:
第一个很简单:使用驼峰命名法,并终如一地保持这种风格。
constmessage='Hello'; constisLoading=true; letcount;这个规则的一个例外是一些特定的值:比如数字或具有特殊含义的字符串。包特定值的变量通常用大写加下划线的形式,与常规变量区分开:
constSECONDS_IN_MINUTE=60; constGRAPHQL_URI='http://site.com/graphql';我认为第二条是:变量名称应该清楚无误地表明是用来保存哪些数据的。
下面是一些很好的例子:
letmessage='Hello'; letisLoading=true; letcount;message名称表示此变量包含某种消息,很可能是字符串。
isLoading也一样,是一个布尔值,用来指示是否正在进行加载。
毫无疑问,count变量表示一个数字类型的变量,其中包含一些计数结果。
一定要选一个能够清楚表明其作用的变量名。
看一个例子,假设你看到了下面这样的代码:
functionsalary(ws,r){ lett=0; for(wofws){ t+=w*r; } returnt; }你能很容易知道函数的作用吗?与薪水的计算有关?非常不幸,我们很难看出ws、r、t、w这些变量名的作用。
但是如果代码是这样:
functioncalculateTotalSalary(weeksHours,ratePerHour){ lettotalSalary=0; for(constweekHoursofweeksHours){ constweeklySalary=weekHours*ratePerHour; totalSalary+=weeklySalary; } returntotalSalary; }我们就很容易知道它们的作用,这就是合理命名的力量。
5.采用中间变量
我一般尽可能避免写注释,更喜欢写出能够自我描述的代码,通过对变量、属性、函数、类等进行合理的命名来表达代码的意图。
如果想使代码本身称为文档,一个好习惯是引入中间变量,这在在处理长表达式时很好用。
比如下面的表达式:
constsum=val1*val2+val3/val4;可以通过引入两个中间变量来提高长表达式的可读性:
constmultiplication=val1*val2; constdivision=val3/val4; constsum=multiplication+division;再回顾一下前面的二叉搜索算法实现:
functionbinarySearch(array,search){ letleft=0; letright=array.length-1; while(left<=right){ constmiddle=Math.floor((left+right)/2); constmiddleItem=array[middle]; if(middleItem===search){ returntrue; } if(middleItem里面的middleItem就是一个中间变量,用于保存中间项。使用中间变量middleItem比直接用array[middle]更容易。
与缺少middleItem变量的函数版本进行比较:
functionbinarySearch(array,search){ letleft=0; letright=array.length-1; while(left<=right){ constmiddle=Math.floor((left+right)/2); if(array[middle]===search){ returntrue; } if(array[middle]没有中间变量的解释,这个版本稍微不太好理解。
通过使用中间变量用代码解释代码。中间变量可能会增加一些语句,但出于增强代码可读性的目的还是非常值得的的。
总结
- 变量无处不在。在JavaScript中使用变量时,首选const,其次是let。
- 尽可能缩小变量的作用域。同样,声明变量时要尽可能靠近其使用位置。
- 合理的命名是非常重要的。要遵循以下规则:变量名称应该清楚无误地表明是用来保存哪些数据的。不要害怕使用更长的变量名:要追求清晰而不是简短。
- 最后,最好用代码自己来解释代码。在高度复杂的地方,我更喜欢引入中间变量。
以上就是如何在JavaScript中正确处理变量的详细内容,更多关于JavaScript处理变量的资料请关注毛票票其它相关文章!