首頁 > web前端 > 前端問答 > es6 symbol屬於基本型別嗎

es6 symbol屬於基本型別嗎

青灯夜游
發布: 2022-03-08 17:00:02
原創
2647 人瀏覽過

es6 symbol屬於基本型別。 symbol是es6中引入的一種新的基本資料類型,表示獨特的值;其作用是防止屬性名的衝突,保證物件中每一個屬性名都是獨一無二的。

es6 symbol屬於基本型別嗎

本教學操作環境:windows7系統、ECMAScript 6版、Dell G3電腦。

Symbol是一種基本資料類型,一種在ES6引入的新的資料類型。

目的是為了防止屬性名的衝突,保證物件中每一個屬性名都是獨一無二的。

let s1 = Symbol('foo');
let s2 = Symbol('foo');

s1 === s2 // false
登入後複製

Symbol型別可以有一個字串參數,表示對Symbol實例的描述。所以相同描述的兩個Symbol型別實例也是不相等的。

如何在物件中使用

let s = Symbol();

// 第一种写法
let a = {};
a[mySymbol] = 'Hello!';

// 第二种写法
let a = {
  [mySymbol]: 'Hello!'
};

// 第三种写法
let a = {};
Object.defineProperty(a, mySymbol, { value: 'Hello!' });

// 以上写法都得到同样结果
a[mySymbol] // "Hello!"
登入後複製

可以看出使用Symbol型別當屬性名,必須使用[]才可以。如果不使用則表示與變數名稱相同字串當屬性名的屬性。

Symbol作為屬性名,遍歷物件的時候,該屬性不會出現在for...infor...of迴圈中,也不會被Object.keys()Object.getOwnPropertyNames()JSON.stringify()回傳

但是,它也不是私有屬性,有一個Object.getOwnPropertySymbols()方法,可以取得指定物件的所有Symbol屬性名稱。此方法傳回一個數組,成員是當前物件的所有用作屬性名的Symbol值。

如何使用同一個Symbol值

Symbol.for("bar") === Symbol.for("bar")
// true
登入後複製

使用Symbol.for()方法,同樣參數所建立的變數就是同一個值。因為使用這個方法建立的Symbol變數會把參數在全域登記。而Symbol()所建立的變數的參數則不會在全域登記。

let s1 = Symbol.for("foo");
Symbol.keyFor(s1) // "foo"

let s2 = Symbol("foo");
Symbol.keyFor(s2) // undefined
登入後複製

使用Symbol.keyFor()則可以變數找到全域登記的參數的名字。

Symbol內建的屬性值

Symbol.hasInstance:其它物件使用instanceof運算子的時候會使用該屬性名稱所指向的內部方法。

Symbol.isConcatSpreadable

#Symbol.species

Symbol.match

Symbol.match

#Symbol.replace

Symbol.search

Symbol.split

Symbol .iterator

Symbol.toPrimitive

Symbol.toStringTagSymbol.unscopables

######【相關推薦:###javascript影片教學###、###web前端###】###

以上是es6 symbol屬於基本型別嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
javascript - es6 Null 傳導運算符
來自於 1970-01-01 08:00:00
0
0
0
JavaScript ES6中 Number.isFinite() 和 Number.isNaN()
來自於 1970-01-01 08:00:00
0
0
0
javascript - ES5的閉包用ES6怎麼實現
來自於 1970-01-01 08:00:00
0
0
0
javascript - ES6的generate問題
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板