大家好,我是零一,JavaScript即将推出两个新的数据类型:Record 和 Tuple ,这俩是啥呢?其实就是一个只读的 Object 和 Array,其实在其它语言中已经有类似的数据类型了,例如 Python 中也有 Tuple(元祖)这一类型,作用也是一个只读的数组(在Python里叫只读的列表),一起来了解一下
其实就是在原先的对象和数组前面加了个 #
Record和Tuple的语法跟对象和数组是一样的,所以?
为啥报错了啊?开头有提到哦~因为这两个类型是 只读的 Object 和 Array
在平时的开发中,数组与数组、对象与对象 都不适合直接用 ===
进行比较判断,因为每个生成的对象在内存中的地址都不一样
要想真正比较两个数组或对象是否相等(即我们想要的内容都一样),需要遍历递归去一一对比,而现在呢?Record和Tuple能否解决这一问题呢?
可以看到,只要内部内容一致,即使是两个分别生成的Record或Tuple比较一下,也是相等的
我可以用对象 Record
和 Tuple
将普通的对象和数组转换
我们也可以对Record和Tuple使用扩展运算符
现在不是有 JSON.parse
和 JSON.stringfy
两个方法嘛,据说草案中还提到一个不错的想法,那就是给 JSON 对象新增一个 parseImmutable
方法,功能应该就是直接将一个 Record字符串或Tuple字符串 解析成对应的Record和Tuple对象
如果你想现在体验该功能,可以装一下babel的插件
在目录下创建 .babelrc
,内容如下:
再创建一个 index.js
,内容如下:
执行一下babel的命令编译一下
输出得到的 compiled.js
文件内容如下:
最后执行 compiled.js
即可获得结果
@babel/plugin-proposal-record-and-tuple
更多用法见 Babel 官方文档 https://babeljs.io/docs/en/babel-plugin-proposal-record-and-tuple#docsNav
了解了那么多的内容,印象最深刻的应该就是 只读 这个特性,那么基于这个特性,Record 和 Tuple 有哪些应用场景呢?
我是零一,分享技术,不止前端!下期见~
「有了这两个新的原始数据类型,你能想到什么应用场景?」欢迎在评论区留言!