JS魔法堂:从void 0 === undefined说起

简介:

一、前言                                    

  当使用coffeescript书写如下代码时 name = person?.name 会被预编译为 var name = typeof person !== "undefined" && person !== null ? person.name : void 0; ,那么void 0到底是什么意思呢?运行得知void 0===undefined为true。那为什么不直接使用undefined而要使用void 0呢?而一元运算符void具体又有什么作用呢?下面将展开来说明。

 

二、为什么不直接用undefined                          

  undefined在JavaScript中并不属于保留字/关键字,因此在IE5.5~8中我们可以将其当作变量那样对其赋值(IE9+及其他现代浏览器中赋值给undefined将无效)

复制代码
var undefinedBackup = undefined;
undefined = 1;
// 显示"undefined"
console.log(typeof undefinedBackup);  
// 在IE5.5~8中显示"number",其他浏览器中则显示"undefined"
console.log(typeof undefined);
复制代码

  于是采用void方式获取undefined则成了通用准则。

 

三、一元运算符void的作用                         

  void在ECMAScript 262规范如下:

The void Operator

The production UnaryExpression : void UnaryExpression is evaluated as follows:

  • Let expr be the result of evaluating UnaryExpression.
  • Call GetValue(expr).
  • Return undefined.

NOTE: GetValue must be called even though its value is not used because it may have observable side-effects.

   void的行为特点为:

  1. 不管void后的运算数是什么,只管返回纯正的undefined;

  2. void会对其后的运算数作取值操作,因此若属性有个getter函数,那么就会调用getter函数(因此会产生副作用)

复制代码
var article = {
    _view: 0,
    get view(){
        console.log(this._view);
    return this._view++;
    }
};
var test = void article.view; // 显示0
console.log(test); // 显示undefined
console.log(article._view); // 显示1
复制代码

   通过一元运算符 delete 作对比,delete的其中一个行为特点是不对其运算数进行取值操作(delete的其他行为特点比我们想的复杂得多,这里就不详细记录了)

复制代码
var article = {
    _view: 0,
    get view(){
    console.log(this._view);
    return this._view++;
    }
};
var ret = delete article.view;
console.log(ret); // 显示true
console.log(article._view); // 显示0
复制代码

 

四、还有啥方式可以得到纯正的undefined?                

  除了通过一元运算符void获取纯正的undefined,其实我们还有如下方法来获取:

  1. 未赋值的变量

var myUndefined;
console.log(typeof myUndefined); // 显示"undefined"

  2. 未赋值的实参(和未赋值的变量同理)

复制代码
var getUndefined = function(undefined){
  return undefined;
};
var myUndefined = getUndefined();
// 或通过arguments获取
var getUndefined = function(){
  return arguments[arguments.length];
};
复制代码

  3. 无返回值函数

var getUndefined = function(){};
var myUndefined = getUndefined();

  4. 未定义的属性

var myUndefined1 = {}[''];
var myUndefined2 = [][0];

 

五、总结                              

  一个小小的void和undefined就这么好玩,前端的世界还有很多事情要深入研究哦!!

  尊重原创,转载请注明来自:http://www.cnblogs.com/fsjohnhuang/p/4146506.html^_^肥子John

 

六、参考                              

谈谈Javascript中的void操作符

如果您觉得本文的内容有趣就扫一下吧!捐赠互勉!

分类: JavaScript
2
0
« 上一篇: JS魔法堂:jsDeferred源码剖析
» 下一篇: JS魔法堂:函数节流(throttle)与函数去抖(debounce)
posted @ 2014-12-05 16:22 ^_^肥仔John 阅读( 5880) 评论( 2) 编辑 收藏
  
#1楼 2016-12-20 09:37 b4b4  
get 新技能

var article = {
_view: 0,
get view(){
console.log(this._view);
return this._view++;
}
};

是时没懂

var article = {
_view: 0,
get view(){
console.log(this._view);
return this._view++;
}
};

get 是什么作用?

对象一般不是这种方式么?
{a:1}
  
#2楼 [ 楼主] 2017-02-20 16:32 ^_^肥仔John  
@ b4b4
ES5特性的getter
相关文章
|
8月前
|
JavaScript 前端开发 程序员
分享18个用于处理 null、NaN 和undefined 的 JS 代码片段
Null、NaN 和 undefined 是程序员在使用 JavaScript 时遇到的常见值。 有效处理这些值对于确保代码的稳定性和可靠性至关重要。
|
8月前
|
JavaScript 前端开发 API
null和undefined:两个JavaScript中的特殊值(二)
null和undefined:两个JavaScript中的特殊值
|
8月前
|
JavaScript 前端开发 安全
null和undefined:两个JavaScript中的特殊值(一)
null和undefined:两个JavaScript中的特殊值
|
JavaScript 前端开发
JavaScript中undefined和not defined的区别
JavaScript中undefined和not defined的区别
|
4月前
|
JavaScript 前端开发
JavaScript如何判断变量undefined
JavaScript如何判断变量undefined
|
4月前
|
机器学习/深度学习 JavaScript 前端开发
JavaScript typeof, null, 和 undefined
JavaScript typeof, null, 和 undefined
64 4
|
4月前
|
存储 JavaScript 前端开发
|
5月前
|
开发者 图形学 C#
揭秘游戏沉浸感的秘密武器:深度解析Unity中的音频设计技巧,从背景音乐到动态音效,全面提升你的游戏氛围艺术——附实战代码示例与应用场景指导
【8月更文挑战第31天】音频设计在游戏开发中至关重要,不仅能增强沉浸感,还能传递信息,构建氛围。Unity作为跨平台游戏引擎,提供了丰富的音频处理功能,助力开发者轻松实现复杂音效。本文将探讨如何利用Unity的音频设计提升游戏氛围,并通过具体示例代码展示实现过程。例如,在恐怖游戏中,阴森的背景音乐和突然的脚步声能增加紧张感;在休闲游戏中,轻快的旋律则让玩家感到愉悦。
145 0
|
5月前
|
前端开发 JavaScript 开发者
JavaScript中的哲学难题:深入探讨undefined与null的情感纠葛
【8月更文挑战第23天】在Web前端开发中,理解和区分`undefined`与`null`至关重要。`undefined`表示变量已声明但未赋值,常出现在未初始化的变量或函数无返回值的情形;`null`则是开发者主动赋值的结果,意味着变量虽存在但值为空。虽然`undefined == null`为真,但`undefined === null`为假,表明它们在语义上有明显差异。合理使用两者能增强代码的健壮性和可读性,避免运行时错误。
39 0
|
7月前
|
JavaScript 前端开发 开发者
JavaScript数据类型概述及Undefined与Null详解
JavaScript数据类型概述及Undefined与Null详解
下一篇
开通oss服务