javascript中undefined的本质解析


Posted in Javascript onJuly 31, 2019

一、列出7种数据类型(面试可能问)

  • Undefined
  • Null
  • Boolean
  • String
  • Number
  • Symbol
  • Object

二、undefined本质

undefined是window对象的一个属性,其类型是Undefined。

javascript中undefined的本质解析

下面解释javascript中属性的本质,因为undefined是一个属性,了解undefine的本质要用到属性的本质。

三、属性本质

对JavaScript来说,属性并非只是简单的名称和值,JavaScript用一组特征(attribute)来描述属性(property)。

先来说第一类属性,数据属性。它比较接近于其它语言的属性概念。数据属性具有四个特征。

  • value:就是属性的值。
  • writable:决定属性能否被赋值。
  • enumerable:决定for in能否枚举该属性。
  • configurable:决定该属性能否被删除或者改变特征值。

补充:第二类属性是访问器(getter/setter)属性,它也有四个特征。 (本文用不到,但可以和第一类属性放在一起记忆)

  • getter:函数或undefined,在取属性值时被调用。
  • setter:函数或undefined,在设置属性值时被调用。
  • enumerable:决定for in能否枚举该属性。
  • configurable:决定该属性能否被删除或者改变特征值。

我们通常用于定义属性的代码会产生数据属性,其中的writable、enumerable、configurable都默认为true。我们可以使用内置函数 Object.getOwnPropertyDescripter来查看,如以下代码所示:

const print = console.log
const o = {a: 1}
o.b = 2
// a和b均为数据属性
const aa = Object.getOwnPropertyDescriptor(o, 'a')
// {value: 1, writable: true, enumerable: true, configurable: true}
const bb = Object.getOwnPropertyDescriptor(o, 'b')
// {value: 2, writable: true, enumerable: true, configurable: true}
print('aa', aa)
print('bb', bb)

javascript中undefined的本质解析

对window对象的undefined施加此函数:

javascript中undefined的本质解析

由此看出undefined是window的第一类属性--数据属性,而且该属性不能能被赋值(writable=false),不能被for in枚举(enumerable=false),不能删除或改变特征值(configurable=false)。这也解释为什么给undefined重新赋值后其值却不改变:因为writable=false

javascript中undefined的本质解析

以及解释为什么不能重新用Object.defineProperty函数定义undefined:因为configurable=false

javascript中undefined的本质解析

注:如果我们要想改变属性的特征,或者定义访问器属性,我们可以使用 Object.defineProperty

javascript中undefined的本质解析

四、Undefined与Null

一个问题,为什么有的编程规范要求用void 0代替undefined?现在我们就分别来看一下。

javascript中undefined的本质解析

Undefined 类型表示未定义,它的类型只有一个值,就是 undefined。任何变量在赋值前是 Undefined 类型、值为 undefined,一般我们可以用全局变量undefined(就是名为undefined的这个变量)来表达这个值,或者 void 运算来把任一一个表达式变成 undefined 值。

但是呢,因为JavaScript的代码undefined是一个变量,而并非是一个关键字,这是JavaScript语言公认的设计失误之一,所以,为了避免无意中被篡改,建议使用 void 0 来获取undefined值。

Undefined跟 null 有一定的表意差别,null表示的是:“定义了但是为空”。所以,在实际编程时,我们一般不会把变量赋值为 undefined,这样可以保证所有值为 undefined 的变量,都是从未赋值的自然状态 。

Null 类型也只有一个值,就是 null,它的语义表示空值,与 undefined 不同,null 是 JavaScript 关键字,所以在任何代码中,你都可以放心用 null 关键字来获取 null 值。

五、总结

undefined是window对象的一个属性其类型是Undefined,属性不是简单的名值对,它还具有一组特征值(attribute)。通过Object.getOwnPropertyDescriptor函数可以得到这组特征值。通过Object.defineProperty函数可以添加一个自定义特征值的属性,在已有属性的特征值configurable为true的前提下也可以通过该函数修改已有属性的特征值。

补充:undefined在全局环境没法被赋值,在局部环境是可以被赋值的!

javascript中undefined的本质解析

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于IE、Firefox、Opera页面呈现异同 写脚本很痛苦
Aug 28 Javascript
jquery中的 $("#jb51")与document.getElementById("jb51") 的区别
Jul 26 Javascript
js弹出层之1:JQuery.Boxy (二)
Oct 06 Javascript
javascript利用apply和arguments复用方法
Nov 25 Javascript
在jQuery中处理XML数据的大致方法
Aug 14 Javascript
基于JS实现二维码图片固定在右下角某处并跟随滚动条滚动
Feb 08 Javascript
详解用node编写自己的cli工具
May 23 Javascript
Mac系统下Webstorm快捷键整理大全
May 28 Javascript
vue.js中v-on:textInput无法执行事件问题的解决过程
Jul 12 Javascript
vue源码学习之Object.defineProperty 对数组监听
May 30 Javascript
解决vue字符串换行问题(绝对管用)
Aug 06 Javascript
vue从后台渲染文章列表以及根据id跳转文章详情详解
Dec 14 Vue.js
JavaScript实现的3D旋转魔方动画效果实例代码
Jul 31 #Javascript
vue 实现滚动到底部翻页效果(pc端)
Jul 31 #Javascript
js实现一个简易计算器
Mar 30 #Javascript
微信小程序iBeacon测距及稳定程序的实现解析
Jul 31 #Javascript
JS获取动态添加元素的方法详解
Jul 31 #Javascript
JS/jQuery实现超简单的Table表格添加,删除行功能示例
Jul 31 #jQuery
详解Vuex下Store的模块化拆分实践
Jul 31 #Javascript
You might like
php中转义mysql语句的实现代码
2011/06/24 PHP
PHP二维数组的去重问题解析
2011/07/17 PHP
PHP strip_tags()去除HTML、XML以及PHP的标签介绍
2014/02/18 PHP
Laravel框架表单验证详解
2014/09/04 PHP
php图像处理函数imagecopyresampled用法详解
2016/12/02 PHP
laravel Model 执行事务的实现
2019/10/10 PHP
Laravel5.5 视图 - 创建视图和数据传递示例
2019/10/21 PHP
js动态给table添加/删除tr的方法
2013/08/02 Javascript
js简单实现用户注册信息的校验代码
2013/11/15 Javascript
css3元素简单的闪烁效果实现(html5 jquery)
2013/12/28 Javascript
js弹出div并显示遮罩层
2014/02/12 Javascript
使用jquery animate创建平滑滚动效果(可以是到顶部、到底部或指定地方)
2014/05/27 Javascript
用C/C++来实现 Node.js 的模块(一)
2014/09/24 Javascript
js为什么不能正确处理小数运算?
2015/12/29 Javascript
jquery.multiselect多选下拉框实现代码
2016/11/11 Javascript
AngularJS中run方法的巧妙运用
2017/01/04 Javascript
vue.js实现条件渲染的实例代码
2017/06/22 Javascript
使用vue-aplayer插件时出现的问题的解决
2018/03/02 Javascript
在Vue中获取自定义属性方法:data-id的实例
2020/09/09 Javascript
python函数局部变量用法实例分析
2015/08/04 Python
Python实现一个简单的验证码程序
2017/11/03 Python
Python何时应该使用Lambda函数
2019/07/02 Python
浅谈Python中文件夹和python package包的区别
2020/06/01 Python
HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
2016/12/14 HTML / CSS
微软瑞士官方网站:Microsoft瑞士
2018/04/20 全球购物
外语系毕业生求职自荐信
2014/04/12 职场文书
升旗仪式演讲稿
2014/05/08 职场文书
雏鹰争章活动总结
2014/05/09 职场文书
代理人委托书
2014/08/01 职场文书
市场营销计划书范文
2015/01/16 职场文书
贷款承诺书
2015/01/20 职场文书
继承公证书格式
2015/01/26 职场文书
2015年学生管理工作总结
2015/05/26 职场文书
清明节主题班会
2015/08/14 职场文书
Python基础之字符串格式化详解
2021/04/21 Python
一起来看看Vue的核心原理剖析
2022/03/24 Vue.js