本文小编为大家详细介绍“JavaScript中原始数据类型Symbol如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript中原始数据类型Symbol如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Symbol
是es6
引入的一个新的原始数据类型,是一个独一无二
的值。目前为止,js
的数据类型有以下几种:Symbol
通过Symbol()
函数生成。对象的属性名现在除了可以使用字符串以外,还可以使用新增的Symbol
类型。如果属性名使用Symbol
,那么它就是独一无二的,不与其它属性名产生冲突。注意:Symbol()
函数前不能使用new
,否则报错。因为生成的Symbol
是一个原始类型的值,而不是对象,所以不能使用new
来调用。而且,Symbol
值不是对象,不能给Symbol
添加属性。可以这么理解,Symbol
是一种类似于字符串的数据类型。Symbol
接收字符串作为参数,表示对Symbol
的描述,添加描述可以用来区分多个Symbol
。如果Symbol
的参数传入的是对象,需要把对象转为字符串再生成Symbol
,否则会显示[object Object]
。Symbol
传入的参数只是一个描述,实际上Symbol
和Symbol
并不相等。每调用一次Symbol()
都会生成一个独一无二的值,每个Symbol
都不相等。Symbol
值不能参与其他类型值的运算,否则报错。Symbol可以转换为字符串如果需要返回Symbol
的描述需要使用es2019
提供的Symbol
实例属性description
返回描述。Symbol可以转换为布尔值(boolean)Symbol
作为属性名Object.defineProperty
使用说明第一个参数:要在其上定义属性的对象第二个参数:要定义或修改的属性的名称第三个参数:将被定义或修改的属性描述符Symbol
值作为对象属性名时,不能用点运算符
获得Symbol
属性,使用点运算符相当于是给对象添加了一个字符串属性名
,而不是获取Symbol
。Symbol
是不可枚举的,Symbol
作为对象键名时,是不可被遍历的,for...in
、Object.keys
等方法都得不到Symbol
键名,并且JSON.stringify()
也不会返回Symbol
。Reflect.ownKeys()
可以返回常规键名和Symbol
键名Object.getOwnPropertySymbols()
只返回Symbol
属性Symbol.for()Symbol
有一个特性就是Symbol
不等于Sombol
,但有时候我们需要同一个Symbol
值Symbol.for()
和Symbol()
都会生成新的Symbol
,前者会被登记在全局环境提供搜索,后者不会。Symbol.for()
每次调用都会先检查参数key
是否存在,如果不存在才会新建一个值。Symbol()
每次调用都会新建一个值。Symbol.keyFor()Symbol.keyFor()
返回已经登记的Symbol
值的key
Symbol.免费云主机域名hasInstance
用来判断某个对象是否为某个构造器实例多个Symbol.hasInstance
会覆盖,只保留最下面的那一个。Symbol.isConcatSpreadable
用于表示Array.prototype.concat()
是否可以展开,true、undefined
可以展开,false
不可展开。对象的Symbol.species
属性指向一个构造函数,创建衍生对象时会使用该属性b
和c
调用的是数组方法,那么应该是Array
的实例,但实际上它们也是MyArray
的实例Symbol.species
可以在创建衍生对象时使用这个属性返回的函数作为构造函数。这里return
了Array
,所以创建的衍生对象使用的Array
作为构造函数,而不是MyArray
。如果这里return
一个String
,那么上面的map、filter
会报错,因为衍生对象使用的是String
作为构造函数,String
是没有数组方法的。Symbol.match
指向一个函数,如果函数存在则会被调用,并返回该方法的返回值读到这里,这篇“JavaScript中原始数据类型Symbol如何使用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注百云主机行业资讯频道。
这篇文章主要介绍了springboot项目数据库密码怎么实现加密的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇springboot项目数据库密码怎么实现加密文章都会有所收获,下面我们一起来看看吧。1、pom.xml引入druid包…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。