当前位置: 首页 > backend >正文

javascript —— ! 和 !! 的区别与作用

javascript —— ! 和 !! 的区别与作用

在 JavaScript 里,! 和 !! 是两种不同的逻辑运算符,它们的功能和使用场景有明显区别。

1、 !(逻辑非运算符)

它的主要作用是 对操作数进行布尔值取反。具体来说,就是 先把操作数转换为布尔值,然后取其相反的值

代码示例:

console.log(!true);     // false
console.log(!false);    // true// 对于非布尔值,会先将其转换为布尔值再取反
console.log(!0);        // true(因为 0 转换为布尔值是 false)
console.log(!'');       // true(空字符串转换为布尔值是 false)
console.log(!null);     // true
console.log(!undefined);// true
console.log(!NaN);      // trueconsole.log(!5);        // false(因为 5 转换为布尔值是 true)
console.log(!'hello');  // false(非空字符串转换为布尔值是 true)
console.log(![]);       // false(空数组是对象,转换为布尔值是 true)
console.log(!{});       // false(空对象转换为布尔值是 true)

2、!!(双重逻辑非运算符)

它其实就是连续使用两次 ! 运算符。先通过第一个 ! 对操作数取反,再用第二个 ! 对取反后的结果再次取反,最终得到的是操作数对应的布尔值。

console.log(!!true);    // true
console.log(!!false);   // false// 对于非布尔值,会将其转换为对应的布尔值
console.log(!!0);       // false
console.log(!!'');      // false
console.log(!!null);    // false
console.log(!!undefined);// false
console.log(!!NaN);     // falseconsole.log(!!5);       // true
console.log(!!'hello'); // true
console.log(!![]);      // true
console.log(!!{});      // true

3、 核心区别

  • !:能将任何值转换为布尔值,并且结果与该值本身的布尔值相反。
  • !!:同样可以把任何值转换为布尔值,但结果和该值本身的布尔值相同。其本质和 Boolean() 函数的作用一样。

4、使用场景

  • !:用于条件判断中取反
const value = null;
if (!value) {console.log('值为假值(false)');
}
  • !!:用于将一个值强制转换为布尔类型,在需要布尔值的场景中经常会用到。
const value = 'hello';
const isTruthy = !!value; // true
console.log(`值是否为真值:${isTruthy}`);

5、在 vue 项目中的使用

(1)!(逻辑非运算符)在 vue 中的使用

模板中的条件判断

在模板里进行条件渲染时,! 可以对数据进行取反操作。

<template><div><!-- 如果 isLoading 为 false,则显示内容 --><div v-if="!isLoading">内容已加载</div><!-- 如果 user 为空,则显示提示 --><div v-if="!user">请先登录</div></div>
</template>
计算属性中返回取反结果

在计算属性里,! 能够返回取反后的布尔值。

<template><div><button :disabled="isDisabled">提交</button></div>
</template><script>
export default {computed: {isDisabled() {// 当表单无效时禁用按钮return !this.formIsValid;}}
}
</script>

(2)!!(双重逻辑非运算符)

强制转换为布尔值

在模板表达式或者计算属性中,!! 能把值强制转换为布尔值,这在需要布尔值的场景中很有用。

<template><div><!-- 将 message 转换为布尔值,判断是否显示消息提示 --><Alert v-if="!!message" :type="messageType">{{ message }}</Alert><!-- 显示数据是否存在的状态 --><span>{{ !!user ? '已登录' : '未登录' }}</span></div>
</template>
监听事件时处理参数

在监听事件并处理参数时,!! 可将参数转换为布尔值。

<template><div><input type="checkbox" @change="handleChange"></div>
</template><script>
export default {methods: {handleChange(event) {// 将事件的选中状态转换为布尔值const isChecked = !!event.target.checked;this.updateStatus(isChecked);}}
}
</script>

(3)Vue 特有的注意事项

在 v-bind 中使用

在使用 v-bind 绑定布尔属性时,!! 可以确保传入的值是布尔类型。

<template><div><!-- 确保 loading 是布尔值 --><Spinner :loading="!!loadingState" /></div>
</template>

(4)对比示例

<template><div class="user-profile"><!-- 使用 ! 进行条件判断 --><div v-if="!user"><button @click="login">登录</button></div><!-- 使用 !! 强制转换为布尔值 --><div v-if="!!user"><img :src="user.avatar" alt="用户头像"><h3>{{ user.name }}</h3><!-- 在计算属性中使用 ! --><button :disabled="!canEdit">编辑资料</button></div></div>
</template><script>
export default {data() {return {user: null, // 假设这是从 API 获取的用户数据canEdit: true}},methods: {login() {// 登录逻辑...}},computed: {// 使用 !! 将值转换为布尔值hasAvatar() {return !!this.user?.avatar;}}
}
</script>

6、总结

  • ! 是取反操作,得到的结果是布尔值,且与原值的布尔值相反。
  • !! 是强制类型转换,得到的结果也是布尔值,和原值的布尔值相同。
http://www.xdnf.cn/news/6505.html

相关文章:

  • 傻子学编程之——数据库如何性能优化
  • 西瓜书【机器学习(周志华)】目录
  • [网络升级指南] 服务器网卡/带宽如何选?1GbE vs 10GbE vs 25GbE+ 性能与成本深度解析 (2025)
  • 香山新篇:海淀低密奢居的典范之作
  • 今日行情明日机会——20250515
  • OpenShift AI - 用 ModelCar 构建容器化模型,提升模型弹性扩展速度
  • 冲刺软考:做减法,走出备考迷茫,高效提分!
  • 学习C++的好书:C++编程之禅
  • Spring类
  • 基于WinCC flexible 2008、STEP_7和博途之间的项目移植
  • rsync入门笔记
  • 【Redis】压缩列表
  • 打破传统束缚:Captiks 无线惯性动捕与步态分析系统如何重新定义运动测量?
  • 【内含文档PPT】基于SSM框架的智能交通信息管理系统
  • day21-线性表(链表III)
  • 网络爬虫学习之httpx的使用
  • 函数专题1
  • 【大模型面试每日一题】Day 19:如何设计自动化评估框架验证大模型的多步推理能力(如数学解题)?
  • 使用Python与正则表达式高效提取Excel中的票号数据
  • 2.Klipper开发篇:Klipper上位机源码分析
  • 时源芯微|TSFE0806U-2L-900TF复合共模滤波器在USB端口保护
  • Python函数参数传递机制深度解析:值传递与引用传递的真相
  • 理解c++中关键字友元friend的作用
  • 盲盒:拆开未知的惊喜,收藏生活的仪式感
  • 现代生活中的创新健康养生之道
  • LLM笔记(二)LLM数据基础
  • 【C++】Module CPP:模块化编程 Demo
  • 【C#】Thread.Join()、异步等待和直接join
  • C++delete详解剖析
  • 工具类来生成蓝牙指令