今天写代码时,突然看到 “!!”运算符,一时竟然没反应过来,再来复习一下?

!!this.isVisit 是一种常见的 JavaScript 编程技巧,用于将 this.isVisit 的值强制转换为布尔类型(truefalse)。它的作用是通过双重逻辑非运算符(!!)确保结果是严格的布尔值。


详细解释

  1. this.isVisit 的含义

    • this.isVisit 是一个对象的属性,可能表示某个状态或标志(例如,用户是否访问过某个页面)。
    • 它的值可能是 undefinednull0""falsetrue 或其他类型。
  2. ! 运算符的作用

    • 第一个 ! 会将 this.isVisit 的值转换为布尔值并取反。
      • 如果 this.isVisittruthy(如 true1"hello"),!this.isVisit 会返回 false
      • 如果 this.isVisitfalsy(如 false0""nullundefined),!this.isVisit 会返回 true
  3. !! 运算符的作用

    • 第二个 ! 会将结果再次取反,从而得到原始的布尔值。
      • 如果 this.isVisittruthy!!this.isVisit 会返回 true
      • 如果 this.isVisitfalsy!!this.isVisit 会返回 false

示例

javascript 复制代码
const user = {
  isVisit: 1, // truthy 值
};

console.log(!!user.isVisit); // true

const guest = {
  isVisit: 0, // falsy 值
};

console.log(!!guest.isVisit); // false

使用场景

  1. 条件判断

    • 确保条件表达式是严格的布尔值。
    javascript 复制代码
    if (!!this.isVisit) {
      console.log("用户已访问");
    } else {
      console.log("用户未访问");
    }
  2. 状态初始化

    • 将可能为 undefinednull 的值初始化为布尔值。
    javascript 复制代码
    const hasVisited = !!this.isVisit;
  3. API 返回值标准化

    • 确保返回的布尔值不会被误解为其他类型。
    javascript 复制代码
    function checkVisit() {
      return !!this.isVisit;
    }

注意事项

  • 如果 this.isVisit 已经是布尔值,!! 是多余的。
  • 对于可能为 nullundefined 的值,!! 是一种简洁的默认值处理方式。

替代方案

如果需要更灵活的类型转换,可以使用 Boolean() 构造函数:

javascript 复制代码
const hasVisited = Boolean(this.isVisit);

效果与 !!this.isVisit 相同,但可读性更高。


总结:!!this.isVisit 是一种快速将任意值转换为布尔值的技巧,适用于需要严格布尔值的场景。

相关推荐
亦世凡华、15 分钟前
Rollup入门与进阶:为现代Web应用构建超小的打包文件
前端·经验分享·rollup·配置项目·前端分享
琉璃℡初雪40 分钟前
vue2/3 中使用 @vue-office/docx 在网页中预览(docx、excel、pdf)文件
vue.js·pdf·excel
Bl_a_ck41 分钟前
【React】Craco 简介
开发语言·前端·react.js·typescript·前端框架
augenstern4162 小时前
webpack重构优化
前端·webpack·重构
海拥✘2 小时前
CodeBuddy终极测评:中国版Cursor的开发革命(含安装指南+HTML游戏实战)
前端·游戏·html
寧笙(Lycode)2 小时前
React系列——HOC高阶组件的封装与使用
前端·react.js·前端框架
asqq82 小时前
CSS 中的 ::before 和 ::after 伪元素
前端·css
拖孩3 小时前
【Nova UI】十五、打造组件库之滚动条组件(上):滚动条组件的起步与进阶
前端·javascript·css·vue.js·ui组件库
苹果电脑的鑫鑫3 小时前
element中表格文字剧中可以使用的属性
javascript·vue.js·elementui
Hejjon3 小时前
Vue2 elementUI 二次封装命令式表单弹框组件
前端·vue.js