Accessor詳解

一、Accessor介紹

Accessor即存取器,是一種用於訪問和設置對象屬性的方式。它允許開發者在獲取對象屬性值或設置對象屬性值時,執行特定的操作,比如進行數據校驗、數據過濾、計算等操作。

在ES5之前,只能通過getter和setter函數實現類似的功能。而ES5引入了Accessor,讓開發者能夠更方便地實現這些功能。Accessor可以理解為getter/setter函數的語法糖。

二、Accessor的語法

//定義一個對象
let obj = {
  _name: "Alice",
  get name() {
    return this._name.toUpperCase();
  },
  set name(value) {
    if (value.length < 4) {
      console.log("Name is too short!");
      return;
    }
    this._name = value;
  }
};

//獲取屬性值
console.log(obj.name); //"ALICE"

//設置屬性值
obj.name = "Bob"; //輸出 "Name is too short!"
obj.name = "Charlie";
console.log(obj.name); //"CHARLIE"

上面的代碼中,obj對象有一個_name屬性,通過get和set方法實現。在獲取name屬性值時,會返回_name的大寫形式;在設置name屬性值時,如果字符串長度小於4,會輸出錯誤信息。如果長度符合要求,則會將字符串賦值給_name屬性。

三、Accessor vs. Getter/Setter函數

在ES5之前,只能通過getter和setter函數實現訪問和設置對象屬性的操作。讓我們來比較一下Accessor和Getter/Setter函數的異同。

1.語法不同

Accessor的語法更加簡單,與普通對象屬性一樣。Getter/Setter函數需要通過Object.defineProperty()方法定義屬性描述符。

2.訪問屬性值的方式不同

Accessor通過對象.屬性名的方式訪問屬性值;而Getter/Setter函數是通過對象調用函數的方式訪問屬性值。

//Getter/Setter函數的使用
let obj = {
  _name: "Alice",
  get name() {
    return this._name.toUpperCase();
  },
  set name(value) {
    if (value.length < 4) {
      console.log("Name is too short!");
      return;
    }
    this._name = value;
  }
};

console.log(obj.getName()); //"ALICE"
obj.setName("Bob"); //輸出 "Name is too short!"
obj.setName("Charlie");
console.log(obj.getName()); //"CHARLIE"

//Accessor的使用
let obj = {
  _name: "Alice",
  get name() {
    return this._name.toUpperCase();
  },
  set name(value) {
    if (value.length < 4) {
      console.log("Name is too short!");
      return;
    }
    this._name = value;
  }
};

console.log(obj.name); //"ALICE"
obj.name = "Bob"; //輸出 "Name is too short!"
obj.name = "Charlie";
console.log(obj.name); //"CHARLIE"

3.操作多個屬性時不同

Accessor可以同時操作多個屬性,而Getter/Setter函數只能操作一個屬性。

//Accessor操作多個屬性
let obj = {
  _firstName: "Alice",
  _lastName: "Green",
  get fullName() {
    return this._firstName + " " + this._lastName;
  },
  set fullName(value) {
    let parts = value.split(" ");
    this._firstName = parts[0];
    this._lastName = parts[1];
  }
};

obj.fullName = "Bob Dylan";
console.log(obj.fullName); //"Bob Dylan"

//Getter/Setter函數只能操作一個屬性
let obj = {};
Object.defineProperty(obj, "name", {
  get: function() {
    return this._name.toUpperCase();
  },
  set: function(value) {
    if (value.length < 4) {
      console.log("Name is too short!");
      return;
    }
    this._name = value;
  }
});

obj.name = "Bob"; //輸出 "Name is too short!"
obj.name = "Charlie";
console.log(obj.name); //"CHARLIE"

四、Accessor的應用場景

1.數據校驗

Accessor允許開發者在設置屬性值前,對屬性值進行校驗。比如,可以針對字符串長度、數值範圍、對象類型等進行校驗。

let obj = {
  _age: 0,
  get age() {
    return this._age;
  },
  set age(value) {
    if (value  100) {
      console.log("Age should be between 0 and 100!");
      return;
    }
    this._age = value;
  }
};

obj.age = -1; //輸出 "Age should be between 0 and 100!"
obj.age = 101; //輸出 "Age should be between 0 and 100!"

2.計算屬性

Accessor允許開發者在獲取和設置屬性值時,執行特定操作,比如進行數據計算、數據過濾、數據轉換等操作。

let obj = {
  _price: 0,
  _quantity: 0,
  get total() {
    return this._price * this._quantity;
  },
  set price(value) {
    this._price = value;
  },
  set quantity(value) {
    this._quantity = value;
  }
};

obj.price = 10;
obj.quantity = 5;
console.log(obj.total); //50

3.數據過濾

Accessor允許開發者在獲取和設置屬性值時,對屬性值進行過濾。比如,可以對字符串進行去除空格、轉換為小寫等操作。

let obj = {
  _name: "",
  get name() {
    return this._name.trim().toLowerCase();
  },
  set name(value) {
    this._name = value;
  }
};

obj.name = "  ALICE ";
console.log(obj.name); //"alice"

五、Accessor的注意事項

雖然Accessor很方便,但是開發者需要注意以下幾點:

1.命名規範

開發者需要遵循屬性命名規範,避免與其他屬性或方法產生衝突。

2.效率問題

Accessor雖然方便,但是運行效率較低。在需要高效運行的場景下,建議使用普通的對象屬性和方法。

3.內存泄漏問題

Accessor可能會引起內存泄漏問題。建議在不需要使用Accessor時,刪除相應的屬性或方法。

4.兼容性問題

Accessor在ES5之前的瀏覽器中沒有實現。如果需要兼容老版本的瀏覽器,建議使用Getter/Setter函數。

六、總結

通過本文的介紹,我們了解了Accessor的語法、與Getter/Setter函數的區別、應用場景以及注意事項。Accessor可以讓開發者更加方便地訪問和設置對象屬性,具有較好的可讀性和可維護性。但是需要合理應用,在性能和兼容性上需要注意。

原創文章,作者:OLDQ,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/131105.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
OLDQ的頭像OLDQ
上一篇 2024-10-03 23:42
下一篇 2024-10-03 23:42

相關推薦

  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁盤中。在執行sync之前,所有的文件系統更新將不會立即寫入磁盤,而是先緩存在內存…

    編程 2025-04-25
  • 神經網絡代碼詳解

    神經網絡作為一種人工智能技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網絡的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網絡模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • Java BigDecimal 精度詳解

    一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變量讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25
  • nginx與apache應用開發詳解

    一、概述 nginx和apache都是常見的web服務器。nginx是一個高性能的反向代理web服務器,將負載均衡和緩存集成在了一起,可以動靜分離。apache是一個可擴展的web…

    編程 2025-04-25
  • 詳解eclipse設置

    一、安裝與基礎設置 1、下載eclipse並進行安裝。 2、打開eclipse,選擇對應的工作空間路徑。 File -> Switch Workspace -> [選擇…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分佈式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25
  • C語言貪吃蛇詳解

    一、數據結構和算法 C語言貪吃蛇主要運用了以下數據結構和算法: 1. 鏈表 typedef struct body { int x; int y; struct body *nex…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性傳感器,能夠同時測量加速度和角速度。它由三個傳感器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25

發表回復

登錄後才能評論