返回顶部
首页 > 资讯 > 精选 >JavaScript的Record和Tuple怎么用
  • 416
分享到

JavaScript的Record和Tuple怎么用

2023-06-29 10:06:08 416人浏览 八月长安
摘要

本篇内容主要讲解“javascript的Record和Tuple怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript的Record和Tuple怎么用”吧!前言JavaScri

本篇内容主要讲解“javascript的Record和Tuple怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript的Record和Tuple怎么用”吧!

前言

JavaScript即将推出两个新的数据类型:Record 和 Tuple ,这俩是啥呢?其实就是一个只读的 Object 和 Array,其实在其它语言中已经有类似的数据类型了,例如 python 中也有 Tuple(元祖)这一类型,作用也是一个只读的数组(在Python里叫只读的列表),一起来了解一下,这个特性是一个第2阶段提案(即差不多稳了)。

基础写法

// Recordsconst myRecord = #{ name: '01',  age: 23}// Tupleconst myTuple = #['1', '2', '3']

其实就是在原先的对象和数组前面加了个 #

可读特性

Record和Tuple的语法跟对象和数组是一样的,所以?

const myRecord = #{ name: '01'}const myTuple = #['1', '2']myRecord['age'] = 23  // errORMyTuple.push('3')  // error

为啥报错了啊?开头有提到哦~因为这两个类型是 只读的 Object 和 Array

非唯一性

在平时的开发中,数组与数组、对象与对象 都不适合直接用 === 进行比较判断,因为每个生成的对象在内存中的地址都不一样

const obj1 = { name: '01' }const obj2 = { name: '01' }const objIsSame = obj1 === obj2   // falseconst arr1 = [1]const arr2 = [1]const arrIsSame = arr1 === arr2   // false

要想真正比较两个数组或对象是否相等(即我们想要的内容都一样),需要遍历递归去一一对比,而现在呢?Record和Tuple能否解决这一问题呢?

const record1 = #{ name: '01' }const record2 = #{ name: '01' }const recordIsSame = record1 === record2   // trueconst tuple1 = #[1]const tuple2 = #[1]const tupleIsSame = tuple1 === tuple2   // true

可以看到,只要内部内容一致,即使是两个分别生成的Record或Tuple比较一下,也是相等的

普通对象和数组的转换

我可以用对象 Record 和 Tuple 将普通的对象和数组转换

const myRecord = Record({ name: '01', age: 23 });   // #{ name: '01', age: 23 }const myTuple = Tuple([1, 2, 3, 4, 5]);   // #[1, 2, 3, 4, 5]

支持扩展运算符

我们也可以对Record和Tuple使用扩展运算符

const myTuple = #[1, 2, 3];const myRecord = #{ name: '01', age: 23 };const newRecord = #{ ...myRecord, money: 0 } // #{ name: '01', age: 23, money: 0 }const newTuple = #[ ...myTuple, 4, 5];   // #[1, 2, 3, 4, 5]

JSON方法扩展

现在不是有 jsON.parse 和 JSON.stringfy 两个方法嘛,据说草案中还提到一个不错的想法,那就是给 JSON 对象新增一个 parseImmutable 方法,功能应该就是直接将一个 Record字符串或Tuple字符串 解析成对应的Record和Tuple对象

提前体验

如果你想现在体验该功能,可以装一下babel的插件

# babel基本的库yarn add @babel/cli @babel/core @babel/preset-env -D# Record和Tuple Babel polyfillyarn add @babel/plugin-proposal-record-and-tuple @bloomberg/record-tuple-polyfill -D

在目录下创建 .babelrc,内容如下:

{    "presets": ["@babel/preset-env"],    "plugins": [        [          "@babel/plugin-proposal-record-and-tuple",          {            "importPolyfill": true,            "syntaxType": "hash"          }        ]      ]}

再创建一个 index.js,内容如下:

const tuple1 = #[1,2,3]const tuple2 = #[1,2,3]const record1 = #{ name: '01' }const record2 = #{ name: '02' }console.log(tuple1 === tuple2, record1 === record2)

执行一下babel的命令编译一下

./node_modules/.bin/babel index.js --out-file compiled.js

输出得到的 compiled.js 文件内容如下:

"use strict";var _recordTuplePolyfill = require("@bloomberg/record-tuple-polyfill");var tuple1 = (0, _recordTuplePolyfill.Tuple)(1, 2, 3);var tuple2 = (0, _recordTuplePolyfill.Tuple)(1, 2, 3);var record1 = (0, _recordTuplePolyfill.Record)({  name: '01'});var record2 = (0, _recordTuplePolyfill.Record)({  name: '02'});console.log(tuple1 === tuple2, record1 === record2);

最后执行 compiled.js 即可获得结果

node compiled.js# Result: true false

应用场景

了解了那么多的内容,印象最深刻的应该就是 只读 这个特性,那么基于这个特性,Record 和 Tuple 有哪些应用场景呢?

  • 用于保护一些数据,比如函数的返回值、对象内部的静态属性...

  • 既然具有只读的特性,即不可变对象,那应该也可以作为对象的 key 值吧?

到此,相信大家对“JavaScript的Record和Tuple怎么用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: JavaScript的Record和Tuple怎么用

本文链接: https://lsjlt.com/news/324185.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript的Record和Tuple怎么用
    本篇内容主要讲解“JavaScript的Record和Tuple怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript的Record和Tuple怎么用”吧!前言JavaScri...
    99+
    2023-06-29
  • JavaScript新增的两个原始数据类型详解(Record和Tuple)
    目录前言基础写法可读特性非唯一性普通对象和数组的转换支持扩展运算符JSON方法扩展提前体验应用场景总结前言 JavaScript即将推出两个新的数据类型:Record 和&...
    99+
    2024-04-02
  • Python的Tuple怎么使用
    本篇内容主要讲解“Python的Tuple怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python的Tuple怎么使用”吧!一 介绍类名:tuple(...
    99+
    2024-04-02
  • Python的元组Tuple怎么用
    这篇文章主要介绍“Python的元组Tuple怎么用”,在日常操作中,相信很多人在Python的元组Tuple怎么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python的元组Tuple怎么用”的疑惑有所...
    99+
    2023-06-29
  • python中tuple怎么使用
    在Python中,元组(tuple)是一个不可变的有序序列,可以存储多个元素。元组可以通过圆括号 () 来创建,并且可以包含任意类型...
    99+
    2023-09-22
    python
  • Typescript中tuple类型怎么用
    小编给大家分享一下Typescript中tuple类型怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!tuple元组类型,允...
    99+
    2024-04-02
  • python怎么取tuple的元素
    要取tuple的元素,可以使用索引操作符[]。索引是从0开始的,所以第一个元素的索引是0,第二个元素的索引是1,以此类推。 以下是一...
    99+
    2024-02-29
    python
  • 使用Python怎么对list、tuple、str和dict进行转换
    使用Python怎么对list、tuple、str和dict进行转换?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、字典(dict)dict = {‘...
    99+
    2023-06-08
  • python中tuple的用法是什么
    在Python中,tuple(元组)是一个有序、不可变、可以包含不同数据类型的数据结构。它类似于列表(list),但不同之处在于元组...
    99+
    2023-09-06
    python
  • Python使用list列表和tuple元组的方法
    list: Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。 比如,列出寝室所有室友的名字,就可以用一个list表示: roo...
    99+
    2024-04-02
  • JavaScript的setTimeout和setInterval怎么用
    这篇文章主要讲解了“JavaScript的setTimeout和setInterval怎么用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript的setTimeout和setI...
    99+
    2023-06-30
  • 一文了解Java中record和lombok的使用对比
    目录小型不可变对象透明的数据载体有许多字段的类可变数据继承性结论大家好,我是指北君。 Java的 record 关键字是Java 14中引入的一个新的语义特性。record 对于创建...
    99+
    2024-04-02
  • C++11标准库tuple模板怎么使用
    这篇文章主要讲解了“C++11标准库tuple模板怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++11标准库tuple模板怎么使用”吧!什么是tuple作者英语一般,在写文章之前...
    99+
    2023-06-19
  • JavaScript的search和replace怎么使用
    今天小编给大家分享一下JavaScript的search和replace怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后...
    99+
    2024-04-02
  • JavaScript中的LHS和RHS怎么用
    本文小编为大家详细介绍“JavaScript中的LHS和RHS怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript中的LHS和RHS怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言:...
    99+
    2023-06-29
  • javascript中的previousSibling和nextSibling怎么用
    previousSibling和nextSibling是用来获取元素节点的前一个兄弟节点和后一个兄弟节点的属性。以下是它们的使用方法...
    99+
    2024-04-02
  • JavaScript的Min和Max方法怎么用
    这篇“ JavaScript的Min和Max方法怎么用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来...
    99+
    2024-04-02
  • JavaScript的try和catch语句怎么用
    这篇文章主要讲解了“JavaScript的try和catch语句怎么用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript的try和catch...
    99+
    2024-04-02
  • JavaScript的Switch、break和default怎么使用
    这篇文章主要讲解了“JavaScript的Switch、break和default怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript...
    99+
    2024-04-02
  • javascript的tostring()和string()函数怎么用
    本篇内容介绍了“javascript的tostring()和string()函数怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、采用...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作