关于!!+Cookies.get(‘sidebarStatus‘)讲解

问题引入

vue-element-admin框架中, vuex的app子模块中有这段代码:

opened: Cookies.get('sidebarStatus') ? !!+Cookies.get('sidebarStatus') : true,

其中的 !!+Cookies.get('sidebarStatus') , 看到的第一眼令人费解



作用及文件位置

作用

  • 控制左侧的 “侧边导航栏” 的展开和折叠
  • 在这里插入图片描述

文件位置

在这里插入图片描述



!!+Cookies.get(‘sidebarStatus’)

详细详解

  1. Cookies.get(‘sidebarStatus’))的意思是取出来的是 "0"
  2. +Cookies.get(‘sidebarStatus’)的意思是 +"0" , 触发隐式类型转换, 会得到 0
  3. !+Cookies.get(‘sidebarStatus’))的意思是 !0 , 对数值类型取反会返回布尔类型, 会得到 true
  4. !!+Cookies.get(‘sidebarStatus’)的意思是 !true , 对布尔的true进行取反, 会得到 false

总结

由于cookie取出的值都是string类型, 但是代码中需要用的是布尔类型,
!!+会把字符串的 “0”, 转成 false,
或者把 字符串的 “1”, 转成 true

  • 16
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值