你可以使用jQuery的三元运算符吗?

问题描述 投票:0回答:3

我使用了一些jQuery来触发if函数。当我尝试使用vanilla javascript的三元操作数来简化等式时,它似乎不起作用。

我究竟做错了什么?

if(windowBottom > objectBottom) {

    $(this).animate({opacity: '1'}, 1500);
    $(this).addClass('item-play__right');
}
//works fine

windowBottom > objectBottom ? $(this).animate({opacity: '1'}, 1500).addClass('item-play__right');
//doesn't work
javascript jquery append operators ternary
3个回答
1
投票

是的,它可以完成,但它需要使用?:

windowBottom > objectBottom ? ($(this).animate({opacity:"1"}, 
1500).addClass("item-play__right")) :'';

没有三元运算符,代码片段也可以写成

windowBottom > objectBottom && ($(this).animate({opacity:"1"}, 
1500).addClass("item-play__right"));

0
投票

这不是您正在使用的有效三元语法,应该有两个可能的结果由:字符分隔。

此外,如果您将其用于副作用而不是计算值,则最好使用if / else


0
投票

你需要?:,否则会导致语法错误。

windowBottom > objectBottom ? $(this).animate({opacity: '1'}, 1500).addClass('item-play__right') : "";
© www.soinside.com 2019 - 2024. All rights reserved.