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

!!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 是一种快速将任意值转换为布尔值的技巧,适用于需要严格布尔值的场景。

相关推荐
IT、木易15 分钟前
大白话 CSS 中transform属性的常见变换类型(平移、旋转、缩放等)及使用场景
前端·css·面试
1024小神35 分钟前
更改github action工作流的权限
前端·javascript
Epicurus40 分钟前
JavaScript无阻塞加载的方式
前端·javascript
1024小神42 分钟前
tauri程序使用github action发布linux中arm架构
前端·javascript
ahhdfjfdf44 分钟前
最全的`Map` 和 `WeakMap`的区别
前端
JYeontu1 小时前
实现一个带@功能的输入框组件
前端·javascript·vue.js
一颗奇趣蛋1 小时前
vue-router的query和params的区别(附实际用法)
前端·vue.js
孤城2861 小时前
MAC电脑常用操作
前端·macos·快捷键·新手·电脑使用
木亦Sam1 小时前
Vue DevTools逆向工程:自己实现一个组件热更新调试器
前端
酷酷的阿云1 小时前
动画与过渡效果:UnoCSS内置动画库的实战应用
前端·css·typescript