JavaScript中原始数据类型Symbol如何使用


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

相关推荐: springboot项目数据库密码怎么实现加密

这篇文章主要介绍了springboot项目数据库密码怎么实现加密的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇springboot项目数据库密码怎么实现加密文章都会有所收获,下面我们一起来看看吧。1、pom.xml引入druid包…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 05/11 19:14
下一篇 05/11 22:17

相关推荐