js三目运算,怎么能简化一下?

let token='';
let b = token == ''?'123':toekn

就这样的逻辑,怎么能简化一下,好像有那种 &&,||,这种东西,用不太明白。

                    header:{
                        'token':uni.getStorageSync('token')!=''?uni.getStorageSync('token'):1,
                        'content-type':'application/x-www-form-urlencoded'
                    }
                  }).then(res => {
                        //token失效过期,跳转到登录页面 
                        if(res.data.code == 401){
                            uni.navigateTo({
                                url:'../../login/login'
                            })
                            return ;
                        })
 'token':uni.getStorageSync('token')!=''?uni.getStorageSync('token'):1,

意思是发现本地token是'',就随便传个值1,给服务器,返回肯定是登录超时了。然后跳转到登录页。

还要一种情况,是token != '',那就直接读出token的值,服务器返回可能是没失效,也可能是失效了。如果失效了,也跳转。没失效则拿到了返回的data数据。

越发感觉设计的像屎一样的逻辑,大家都怎么做的。

阅读 5k
6 个回答

||是‘或’的意思,会判断左边是否有值,即会使用Boolean将左边进行转化,若为true,返回左边的值,若为false,返回右边的值
token || '123'
&&是并且的意思,会判断左边是否有值,即会使用Boolean将左边进行转化,若为false,返回左边的值,若为true,返回右边的值
ES2020 新增了一个运算符 ??。当左侧的操作数为 null 或者 undefined时,返回其右侧操作数,否则返回左侧操作数。

楼上说的没啥毛病,再补充一种??
当token为null或者undefined的时候才会返回右边的值

var token
token ?? 2 // 返回2
var token = null
token ?? 2 // 返回2
var token = ''
token ?? 2 // 返回''
let token
let b = token || '123'

image.png
image.png

如果便于阅读的话,可以用 if 替代三目

let token = '';
let b = token;
if (!token) {
    b = '123';
}
let token='';
let b = token || '123'

js还有最新的规范逻辑赋值

let token='';
token ||= '123' // '123'

更多逻辑赋值??=、&&=你可以你看下文档;

需要注意一点的是,逻辑运算符,||&& 在大多数语言中,都是始终返回布尔值。

但是在,JS 中则是返回成立项。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题