这样的一个三元运算有什么问题?

一个简单的判断替换字符串而已,自己看起来好像没有什么问题,目的是如果state为空或者未定义默认为“online”,现结果是当state为“offline”时依旧输出了“online”。


var state = optionsEntity.state;  //state已确认为“offline”

var states = function(state){

    return state == "" ? "online" : (state=state||"online");

};

    console.log(states());  //输出结果是“online”

是因为三元中这样的嵌套式错误的吗?


翻阅古今
浏览 408回答 3
3回答

心有法竹

var states = function(state){  // 这里既然有参数为什么下面调用的时候不传值?这里面的state只是你定义的一个名称而已,它又不会帮你去外面找名字一样的放进来    console.log(state)  // undefined    return state == "" ? "online" : (state=state||"online");};正确的调用姿势console.log(states(state)) // offline上面有答案把function里面的参数去掉就可以了,简单解释一下,是因为你在外面定义的state是全局变量,而在function里面的参数是局部变量,当function执行的时候它会首先找到内部定义的变量,再往外找,这里你如果把参数名改成其他的,不和外面的重名,输出也会变成正常的offline

慕哥6287543

var states = function(state){    return state == "" ? "online" : (state=state||"online");};改为var states = function(){    return state == "" ? "online" : (state=state||"online");};

动漫人物

console.log()没有传值啊,console.log(states(state ))
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript