js的if判断问题

发布于 2022-09-01 23:27:17 字数 245 浏览 17 评论 0

e = window.event || e;
if((e.target && e.target.className && e.target.className == "")){
    return;
}

为什么if的判断为false,我的e.target,e.target.className都是存在的,e.target.className也确实为"",求问这样写为什么进不去return?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(12

一身骄傲 2022-09-08 23:27:17

e.target.className=="" ,在js中 "" 就是false,
因此 e.target.className=="" true,e.target.className 是false;e.target.className=="" false,e.target.className 是true

由此可见,该判断永远都不会进入return,2,3条件是相悖的。

楼主是想通过e.target.className判断Class属性是否存在,但是不应该这么写!

我只土不豪 2022-09-08 23:27:17

e.target.className && e.target.className == "" 问题所在,两个不能共存啊。

茶花眉 2022-09-08 23:27:17

e.target.className这个有问题
如果是“”,就会判断为失败。
if((e.target && e.target.className === "")){

return;

}
改成这个试试

为人所爱 2022-09-08 23:27:17

e.target && e.target.className && e.target.className == ""这个表达式在第二步 e.target.className就为false了你以为还会判断下一个false true。

风月客 2022-09-08 23:27:17

能不能放详细的代码?

草莓味的萝莉 2022-09-08 23:27:17

逻辑有问题,存在又为空,悖论。

剩余の解释 2022-09-08 23:27:17
  1. &&逻辑运算符有短路特性

  2. 空字符串转换成成逻辑值就为false

var p='';
if(p){
    console.log("true");
}else{
    console.log("false");
}
//输出false
赠意 2022-09-08 23:27:17

第二个为空,就跳出去了。

若水般的淡然安静女子 2022-09-08 23:27:17

→_→ 第二个条件有必要吗

你爱我像她 2022-09-08 23:27:17
!"";
//true
//当一个空的字符做逻辑运算的时候会被转为false
if(true&&""){
    
}
活泼老夫 2022-09-08 23:27:17

你这写法,在第二个条件中就被干掉了。因为 JavaScript 对于假值这个东西还是比较宽松的,在条件语句中像 0, false, '', undefined, null, NaN 都会自动转为 false

怂人 2022-09-08 23:27:17

当e.target.classname==""时,第二个条件为false,&&就跳出去了,所以没法到return那里。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文