三元、或、且运算符妙用

2019/07/04 posted in  JavaScript
Tags: 

句式一、

if(a) do_a

elseif(b) do_b

else do_c

转化为:

=>a ? do_a

: b ?do_b

: do_c

句式二、

if(a) do_a

转化为:

=> a &&do_a

句式三、

if(!a) do_a

转化为:

=> a || do_a

三元:

//if else 实现
var add_level = 0; 
if(add_step == 5){ 
  add_level = 1; 
}else if(add_step == 10){ 
  add_level = 2; 
}else if(add_step == 12){ 
  add_level = 3; 
}else if(add_step == 15){ 
  add_level = 4; 
}else { 
  add_level = 0; 
} 
//也可以用switch实现
var add_level = 0; 
switch(add_step){ 
  case 5 : 
    add_level = 1; 
    break; 
  case 10 : 
    add_level = 2; 
      break; 
  case 12 : 
     add_level = 3; 
    break; 
  case 15 :
    add_level = 4; 
    break; 
  default : 
    add_level = 0; 
    break;
} 
//&& ||实现
var add_level = (add_step==5 && 1) || (add_step==10 && 2) || (add_step==12 && 3) || (add_step==15 && 4) || 0;
//更优雅的方式
var add_level={'5':1,'10':2,'12':3,'15':4}[add_step] || 0; 

几乎所有语言中||和&&都遵循“短路”原理,如&&中第一个表达式为假就不会去处理第二个表达式,而||正好相反。

一方面精简js代码,能实质性的减少网络流量,尤其是大量应用的js公用库。个人比较推荐的做法是:如果是相对复杂的应用,请适当地写一些注释。这个和正则表达式一样,能够精简代码,但是可读性会降低,对读代码的人要求会高些,最好的办法就是写注释。

« 再谈JavaScript模块化 vue cli3.0使用说明 »