中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

怎么在es6中實現元編程

發布時間:2020-12-01 15:00:23 來源:億速云 閱讀:189 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關怎么在es6中實現元編程,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

何為元編程?

「編寫能改變語言語法特性或者運行時特性的程序」。換言之,一種語言本來做不到的事情,通過你編程來修改它,使得它可以做到了,這就是元編程。

meta-programming元編程中的 元 的概念可以理解為 程序 本身。”元編程能讓你擁有可以擴展程序自身能力

舉個例子:

if (a == 1 && a == 2 && a == 3) {
  console.log("done");
}

怎樣才能讓這個條件滿足,輸出done。按照正常的邏輯是無法完成的,畢竟一個值不可能同時滿足等于1、2、3

這是就可以用到元編程來改變這個不可能

let a = {
  [Symbol.toPrimitive]: ((i) => () => ++i)(0)
}

if (a == 1 && a == 2 && a == 3) {
  console.log("done");
}
// done

Symbol.toPrimitive在對象轉換為原始值的時候會被調用,初始值為1,調用一次+1,就可以滿足a == 1 && a == 2 && a == 3,同時Symbol.toPrimitive也可以接受一個參數hint,hint的取值為number、string、default

let obj = {
  [Symbol.toPrimitive](hint) {
    switch (hint) {
      case "number":
        return 123;
      case "string":
        return "str";
      case "default":
        return "default";
    }
  }
}
console.log(1-obj); // -122
console.log(1+obj); // 1default
console.log(`${obj}`); // str

還有哪些元編程?

proxy

es5的Object.defineProperty()方法的es6升級版,用于自定義的對象的行為

let leon = {
  age: 30
}
const validator = {
  get: function(target, key){
    // 若沒這個屬性返回37
    return key in target ? target[key] : 37;
  },
  set(target,key,value){
    if(typeof value!="number" || Number.isNaN(value)){
      throw new Error("年齡得是數字");
    }
  }
}
const proxy = new Proxy(leon,validator);
console.log(proxy.name);
// 37
proxy.age = "hi";
// Error: 年齡得是數字

reflect-metadata

你可以通過裝飾器來給類添加一些自定義的信息。然后通過反射將這些信息提取出來。當然你也可以通過反射來添加這些信息

require("reflect-metadata")
class C {
  // @Reflect.metadata(metadataKey, metadataValue)
  method() {
  }
}
Reflect.defineMetadata("name", "jix", C.prototype, "method");

let metadataValue = Reflect.getMetadata("name", C.prototype, "method");
console.log(metadataValue);
// jix

應用

拓展數組索引訪問

負索引訪問,使array[-N] 與 array[array.length - N] 相同

let array = [1, 2, 3];

array = new Proxy(array, {
 get(target, prop, receiver) {
  if (prop < 0) {
   console.log(prop, 'prop')
   prop = +prop + target.length;
  }
  return Reflect.get(target, prop, receiver);
 }
});


console.log(array[-1]); // 3
console.log(array[-2]); // 2

數據劫持

let handlers = Symbol('handlers');

function makeObservable(target) {
 // 初始化存儲 handler 的數組
 target[handlers] = [];

 // 存儲 handler 函數到數組中以便于未來調用
 target.observe = function(handler) {
  this[handlers].push(handler);
 };

 // 創建代理以處理更改
 return new Proxy(target, {
  set(target, property, value, receiver) {
   // 轉發寫入操作到目標對象
   let success = Reflect.set(...arguments);
   // 如果設置屬性的時候沒有報錯
   if (success) {
    // 調用所有 handler
    target[handlers].forEach(handler => handler(property, value));
   }
   return success;
  }
 });
}

let user = {};

user = makeObservable(user);

user.observe((key, value) => {
 console.log(`SET ${key}=${value}`);
});

user.name = "John";
// SET name=John

上述就是小編為大家分享的怎么在es6中實現元編程了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

阜平县| 波密县| 葵青区| 渭南市| 香河县| 额济纳旗| 祁东县| 盐津县| 富顺县| 元谋县| 湖北省| 天门市| 台安县| 麟游县| 电白县| 博野县| 武汉市| 黎城县| 黔西县| 长寿区| SHOW| 婺源县| 大邑县| 安康市| 普陀区| 宜昌市| 普定县| 合阳县| 红桥区| 固原市| 太保市| 宿松县| 东至县| 涡阳县| 崇明县| 宁阳县| 嵊泗县| 德清县| 光山县| 吉安县| 昌平区|