成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript 新增兩個原始數據類型

開發 前端
大家好,我是ConardLi,JavaScript即將推出兩個新的數據類型:Record 和 Tuple ,這倆是啥呢?其實就是一個只讀的 Object 和 Array,其實在其它語言中已經有類似的數據類型了。

基礎寫法

// Records
const myRecord = #{
name: '01',
age: 23
}
// Tuple
const myTuple = #['1', '2', '3']

其實就是在原先的對象和數組前面加了個 #

可讀特性

Record和Tuple的語法跟對象和數組是一樣的,所以?

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

為啥報錯了啊?開頭有提到哦~因為這兩個類型是 只讀的 Object 和 Array

非唯一性

在平時的開發中,數組與數組、對象與對象 都不適合直接用 === 進行比較判斷,因為每個生成的對象在內存中的地址都不一樣

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

要想真正比較兩個數組或對象是否相等(即我們想要的內容都一樣),需要遍歷遞歸去一一對比,而現在呢?Record和Tuple能否解決這一問題呢?

const record1 = #{ name: '01' }
const record2 = #{ name: '01' }
const recordIsSame = record1 === record2 // true
const 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 polyfill
yarn 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

責任編輯:龐桂玉 來源: code秘密花園
相關推薦

2020-11-23 10:25:44

tcpdump數據包Linux

2022-06-17 09:46:51

Chrome 102Chrome瀏覽器

2020-12-29 07:56:23

JavaScript數據類型 primitive

2016-08-18 14:13:55

JavaScript基本數據引用數據

2010-10-08 15:11:28

JavaScript數

2021-12-03 15:24:45

Javascript數據類型

2012-10-18 09:24:14

Office 365

2022-01-14 10:59:07

數據包tcpdump

2010-10-08 09:02:03

JavaScript基

2011-07-29 10:12:12

JavaScript

2014-01-09 10:07:18

JavaScriptNull

2010-09-13 09:58:17

SQL Server2

2018-11-15 09:45:47

JavaScript數據類型變量

2025-02-25 10:03:20

2022-08-12 16:12:34

JavaScript數據類型字符串

2017-02-27 08:34:09

JavaScript數據引用

2013-01-18 09:41:24

PaaS云存儲紅帽Linux

2017-12-26 10:48:37

深度學習原始數據

2014-01-05 17:08:09

PostgreSQL數據類型

2019-08-12 11:40:48

數據庫SQLite3數據類型
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲日本一区二区 | 久久综合久久久 | 五月婷婷视频 | 美日韩一区二区 | 精品一区二区电影 | 日韩一区二区三区在线 | 国产亚洲人成a在线v网站 | 99热精品6| 中文字幕成人av | 精品国产一区二区久久 | 亚洲91视频| 一级免费毛片 | 欧美日韩精品中文字幕 | 久久精品男人的天堂 | 国产欧美日韩综合精品一区二区 | 国产精品三级 | 国产精品自拍视频 | 99热这里有精品 | 日日精品 | 国产精品1区2区 | 国产传媒 | 成人中文字幕在线观看 | 精品久久香蕉国产线看观看亚洲 | 精品中文在线 | 91免费在线播放 | 日韩第一区| 国产精品久久九九 | 亚洲成人av| 亚洲区一区二区 | a久久久久久 | www国产精品| 国产精品精品久久久 | 午夜激情免费视频 | 精品久久久久一区二区国产 | 国产精品成人在线播放 | 中文字幕成人在线 | 91久久久久 | 亚洲 欧美 日韩 在线 | 国产在线看片 | 日韩精品福利 | 欧美性久久 |