关于JS三目运算符问题

在三目运算符中使用字符串连接符为什么在条件改变时结果却不变?

        var notice = "she is "+true? "?":"nt"+" here."
        alert(notice);    // "?"

        var notice = "she is "+false? "?":"nt"+" here."
        alert(notice);    // "?"

但是,去掉三目运算符前的字符串连接符及字符串就恢复正常了

        var notice = false? "?":"nt"+" here."
        alert(notice);    // "nt here."

        var notice = true? "?":"nt"+" here."
        alert(notice);    // "?"

求解?

阅读 4.6k
3 个回答

首先:
什么是三目运算符?
{1} ? {2} : {3} ;
JS引擎首先执行 Boolean({1}) 如果为 True 则返回 {2}False则返回{3}
然后:
"she is "+true === "she is true" //严格相等
所以
Boolean("she is "+true) === Boolean("she is true") // 等于 True
Boolean("she is "+false) === Boolean("she is false") // 也等于 True


但是:
false? "?":"nt"+" here." 中的false是布尔值.
所以Boolean(false) === false
所以Boolean(true) === true

这是一个运算符优先级问题. 首先+(字符串连接运算符)优先级比?:(三目运算符)优先级高,所以先执行+运算符.
所以两种情况下,分别得到"she is "+true"she is "+false.
再执行三目元算符,但是"she is "+true"she is "+false(String,除了"")转换成Boolean均为true. 所以三目运算符条件为真,所以得到结果为"?".

var notice = "she is "+(true? "?":"nt")+" here."
        alert(notice);    // "?"
var notice = "she is "+(false? "?":"nt")+" here."
        alert(notice);    // "?"
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题