一个简单的判断替换字符串而已,自己看起来好像没有什么问题,目的是如果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”是因为三元中这样的嵌套式错误的吗?
3 回答
心有法竹
TA贡献1866条经验 获得超5个赞
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
TA贡献1831条经验 获得超10个赞
var states = function(state){
return state == "" ? "online" : (state=state||"online");
};
改为
var states = function(){
return state == "" ? "online" : (state=state||"online");
};
添加回答
举报
0/150
提交
取消