这的写法
这里有三个地方你可能需要补习:
一、短路执行
如果一行代码为“A && B”,则只有A的值为true时,JS才会执行到B,否则不会执行B
相当于 if(A){B}
二、无效值
如果一行代码为“A=B||C”,则表示如果B是有效的值则A=B,否则A=C
那什么是无效值呢?就是与false等效的这几个值:0、空字符串、未定义的变量。
当B等于这几个值的时候,A就被赋值为C
三、三元运算符
如果一行代码为“A?B:C”,则表示如果A为true则执行B,否则执行C
用以上三点可以解释你的代码:
//先格式化一下
smAddToCart.add = function(a, b, c, d) {
0 != b && (
this.ele = a,
this.sku = b,
this.ptype = d || 1,
this.pcount = c || 1,
0 === this.addVersion && (this.addVersion = this.getAbTest()),
1 === this.addVersion ? this.versonModal() : 2 === this.addVersion && this.versonAnimate()
)
}
一、短路
当0!=b时,执行&&后面括号内的语句,否则这些语句都不会被执行。
0 === this.addVersion && (this.addVersion = this.getAbTest()) 这一行也是同样道理
二、无效值
“this.ptype=d||1” 表示当d的值为false、0、空字符串或未定义时,this.ptype就等于1,否则this.ptype=d。下面一行同样道理。
三、三元运算
1 === this.addVersion ? this.versonModal() : 2 === this.addVersion && this.versonAnimate()
表示如果1 === this.addVersion,则执行this.versonModal()方法,否则执行2 === this.addVersion && this.versonAnimate()方法
后面这个方法也是短路
//翻译成大家都能看懂的代码:
smAddToCart.add = function(a, b, c, d) {
if(0 != b){
this.ele = a;
this.sku = b;
if(d){
this.ptype = d ;
}else{
this.ptype = 1;
}
if(c){
this.pcount = c;
}else{
this.pcount = 1;
}
if(0 === this.addVersion){
this.addVersion = this.getAbTest();
}
if(1 === this.addVersion){
this.versonModal();
else{
if(2 === this.addVersion ){
this.versonAnimate()
}
}
}
}