void运算符的作用及使用场景解析
时间:2026-01-06 16:54:42 340浏览 收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《JavaScript中void运算符的作用及使用场景》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
void运算符总是返回undefined,不改变变量值或内存状态,仅丢弃表达式结果;它用于IIFE防解析错误、javascript:void(0)阻止跳转,且比直接写undefined更安全可靠。

void 运算符到底返回什么
它总是返回 undefined,不管右边表达式是什么。这不是“清空值”或“销毁变量”,只是求值后强制丢弃结果、固定返回 undefined。
常见误解是把它当“释放内存”或“重置变量”,其实完全无关——void 不影响任何变量的生命周期或值,只影响当前表达式的返回值。
void 0、void false、void "hello"全部等价于undefined- 它比直接写
undefined更可靠:在旧版 IE 中全局undefined可被覆盖,而void 0永远安全 - 运算符优先级较低,常需括号:比如
void (x = 1)才能确保赋值执行后再丢弃结果
为什么在 IIFE 前加 void
避免函数声明被解析为函数语句(Function Statement),强制 JavaScript 引擎按函数表达式(Function Expression)处理,从而允许立即调用。
不加 void 时:
function() { console.log('hi'); }() 会报 SyntaxError: Unexpected token '(',因为引擎认为这是非法的函数声明语法。
void function() { ... }()合法:void让整个结构变成表达式,括号才被允许- 其他等效写法还有:
!function(){}()、+function(){}()、(function(){})(),但void最语义清晰——明确表示“我不关心返回值” - 现代代码普遍用
(function(){})(),但void在压缩工具(如 UglifyJS)中更省字节:void比(和)总共少 1 字符
void 在 href="javascript:void(0)" 中的真实作用
阻止浏览器跳转或刷新页面,同时不触发任何副作用——它不是“防止默认行为”的万能解,而是利用了 javascript: 伪协议的执行机制。
点击链接时,浏览器会执行 javascript: 后面的代码,并把返回值当作新 URL 加载;若返回 undefined,则不跳转。
href="javascript:void(0)"→ 执行void 0→ 返回undefined→ 页面停留href="javascript:0"也有效(返回数字 0,非字符串,不会触发跳转),但语义模糊- ⚠️ 现代开发应避免这种写法:它对键盘导航、屏幕阅读器不友好,且无法禁用右键保存;推荐用
event.preventDefault()+或带role="button"的元素
容易被忽略的陷阱
void 是一元运算符,不能省略操作数;而且它不阻止表达式本身的副作用——只管“扔掉返回值”,不管“有没有执行”。
void console.log('side effect')依然会打印日志,只是返回undefinedvoid delete obj.key会真正删除属性,然后返回undefined- 在严格模式下,
void this返回undefined(而非全局对象),这点和非严格模式不同 - 不要用
void替代条件判断:比如if (void x) {...}永远为假,因为void总是返回undefined,而undefined是 falsy
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
403 收藏
-
290 收藏
-
473 收藏
-
301 收藏
-
105 收藏
-
269 收藏
-
218 收藏
-
427 收藏
-
206 收藏
-
464 收藏
-
461 收藏
-
246 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习