91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ES6中Symbol類型用法實例詳解

發布時間:2020-09-13 10:01:52 來源:腳本之家 閱讀:230 作者:布瑞澤的童話 欄目:web開發

本文實例講述了ES6中的Symbol類型。分享給大家供大家參考,具體如下:

Symbol是在ES6中新加入的類型。

正如我們所知,JavaScript中有以下幾種類型:

Undefined ,Null ,Boolean ,Number ,String, Object

但是上述類型在處理某些情況的時候是遠遠不夠的。下面我們來舉一個例子:

假設我們要移動div,也需要在某些情況下判斷該div是否處于移動狀態,所以我們會想到給div這類的對象設置一個屬性。

if (element.isMoving) {
 smoothAnimations(element);
}
element.isMoving = true;

但是這樣會存在一些問題,比如:

我們可能和第三方的庫沖突

我們可能和未來的標準沖突等

于是可以采用第二種方法,也就是采用加密函數,制定一個值:

var isMoving = SecureRandom.generateName();
...
if (element[isMoving]) {
 smoothAnimations(element);
}
element[isMoving] = true;

這樣確實解決了沖突問題,但卻帶來了調試問題,我們每次查看該對象屬性時都會看見一大堆垃圾命名。

于是為了解決沖突問題,ES6提出了Symbol這樣的新類型。

Symbol是一種特殊的、不可變的數據類型,可以作為對象屬性的標識符使用。我們看demo:

var sym1 = Symbol();
var sym2 = Symbol("foo");
var sym3 = Symbol("foo");

Symbol("foo") 不會強制字符串 "foo" 進入一個Symbol,它每次都創建一個新的Symbol

Symbol("foo") === Symbol("foo"); // false

所以可以利用這個特性來創建私有屬性:

(function() {
 // 創建symbol
 var key = Symbol("key");
 function MyClass(privateData) {
  this[key] = privateData;
 }
 MyClass.prototype = {
  doStuff: function() {
   ... this[key] ...
  }
 };
})();
var c = new MyClass("hello")
c["key"] === undefined//無法訪問該屬性,因為是私有的

也可以利用Symbol來解除上面所說的沖突問題:

// create a unique symbol
var isMoving = Symbol("isMoving");
...
if (element[isMoving]) {
 smoothAnimations(element);
}
element[isMoving] = true;

當然,也可以通過另外的調用方法來生成可以與外界共享的Symbol類型,就是Symbol.for方法

Symbol.for(key) 方法會根據給定的鍵 key,來從 symbol 注冊表中找到對應的 symbol,如果找到了,則返回它,否則,新建一個與該鍵關聯的 symbol,并放入 symbol 注冊表中。

Symbol.for("foo"); // 創建一個 symbol 并放入 symbol 注冊表中,鍵為 "foo"
Symbol.for("foo"); // 從 symbol 注冊表中讀取鍵為"foo"的 symbol
Symbol.for("bar") === Symbol.for("bar"); // true,證明了上面說的
Symbol("bar") === Symbol("bar"); // false,Symbol() 函數每次都會返回新的一個 symbol
var sym = Symbol.for("mario");
sym.toString();
// "Symbol(mario)",mario 既是該 symbol 在 symbol 注冊表中的鍵名,又是該 symbol 自身的描述字符串

所以為了防止沖突,我們最好給symbol帶上前綴:

Symbol.for("mdn.foo");
Symbol.for("mdn.bar");

希望本文所述對大家ECMAScript程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

盐山县| 那坡县| 华安县| 永清县| 莆田市| 兴安县| 成安县| 英超| 鹤壁市| 重庆市| 丽江市| 蓬溪县| 翁源县| 祁门县| 洪泽县| 嘉峪关市| 广东省| 古浪县| 张家港市| 永嘉县| 宜良县| 灵台县| 大城县| 萨嘎县| 类乌齐县| 天台县| 上虞市| 田林县| 北川| 抚顺县| 甘南县| 闽清县| 盐城市| 崇文区| 通渭县| 定西市| 甘洛县| 上高县| 镶黄旗| 昭通市| 星子县|