」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 屬性存取器

屬性存取器

發佈於2024-11-04
瀏覽:780

Property accessors

了解 JavaScript 中的属性访问器

在 JavaScript 中,属性访问器是允许您访问对象属性的机制。有两种主要方法可以做到这一点:点表示法和方括号表示法。

点符号

点表示法是访问属性的最常见方法。您只需使用点 (.) 后跟属性名称即可。

括号表示法

当属性名称是动态的或不是有效的标识符(例如,它包含空格或特殊字符)时,括号表示法很有用。您使用方括号 ([]) 并将属性名称作为字符串传递

在 JavaScript 中创建对象

该语言提供了称为对象文字表示法的语法,用于快速创建对象。对象字面量用花括号表示。以下示例创建一个没有属性的空对象。

var animal = {};

在花括号内,属性及其值被指定为键/值对列表。
键可以是字符串或标识符,而值可以是任何有效的表达式。键/值对列表以逗号分隔,每个键和值用冒号分隔。

以下示例使用文字表示法创建一个具有三个属性对象。

第一个属性,动物,占据第一位。
第二个属性 dolphin 使用字符串指定,并且还存储字符串值。第三个属性,哺乳动物,存储一个空对象。

var animal = {
  dolphin: 1,
  "swim": "some string",
  mammal: {
  }
};

每个属性都写在单独的行上并缩进。整个对象可以写在一行上,但这种格式的代码更具可读性。对于具有许多属性的对象或嵌套对象尤其如此。

JavaScript 提供了两种用于访问对象属性的表示法。

第一个也是最常见的,被称为点符号
在点表示法下,通过给出主机对象的名称、后跟句点(或点)、再后跟属性名称来访问属性。

点符号

点表示法是访问属性的最常见方法。您只需使用点 (.) 后跟属性名称即可。例如:

以下示例显示如何使用点表示法读取和写入属性。如果对象.dolphin
最初的值为1,执行该语句后其值将变为2。

  • 请注意,如果animal.dolphon 还没有值,那么它将是未定义的。
animal.dolphin = animal.dolphin   1;

访问对象属性的语法称为括号表示法。在括号表示法中,对象名称后跟一组方括号
方括号 内,属性名称指定为 字符串
前面的点表示法示例已在下面重写为使用括号表示法。虽然代码可能看起来不同,但它在功能上与前面的示例相同。

object["dolphin"] = object["dolphin"]   1;

括号表示法点表示法更具表现力,因为它允许变量指定全部或部分属性名称
这是可能的,因为 JavaScript 解释器会自动将方括号内的表达式转换为字符串,然后检索相应的属性

以下示例演示如何使用括号表示法动态创建属性名称。在示例中,属性名称 foo 是通过将变量 d 的内容与字符串“dolphin”连接起来创建的。

var d = "d";

object[d   "dolphin"] = "bar";

括号表示法还允许属性名称包含点表示法禁止的字符。
例如,以下语句在括号表示法中是完全合法的。但是,如果您尝试以点表示法创建相同的属性名称,则会遇到语法错误。

object["!@#$%^&*()."] = true;

访问嵌套属性

嵌套对象的属性可以通过将点和/或括号引用链接在一起来访问。
例如,以下对象包含一个名为 dolphin 的嵌套对象,该对象包含另一个名为哺乳动物的对象,该对象具有一个名为years 的属性,该属性的值为 one。

var animal = {
  dolphin: {
    mammal: {
      years: 1
    }
  }
};

以下表达式访问嵌套属性years。第一个表达式使用 点表示法 ,而第二个表达式使用 方括号表示法
第三个表达式结合了 两种表示法以获得相同的结果.

animal.dolphin.mammal.lungs;
animal["dolphin"]["mammal"]["years"];
animal["dolphin"].mammal["years"];

如果使用不当,像上一个示例中所示的表达式可能会导致性能下降。
计算每个 点或括号表达式 需要时间。

如果多次使用同一属性,则更有意义的是访问该属性一次,然后将该值存储在局部变量中以供将来使用。以下示例在循环内多次使用 bar。然而,bar 不是浪费时间反复计算相同的值,而是存储在局部变量中。

var years = animal.dolphin.mammal.years;
var count = 0;

for (var i = 0; i 



函数作为方法

当函数用作对象属性时,它被称为方法。与属性一样,方法也可以用对象文字表示法指定。以下示例显示了这是如何完成的。

var animal = {
  sum: function(dolphin, years) {
    return dolphin   years;
  }
};

方法也可以使用点和括号表示法调用。
以下示例 使用两种表示法调用 上一个示例中的 sum() 方法。

dolphin.sum(1, 2);
dolphin["sum"](1, 2);

添加属性和方法

对象字面量表示法对于创建新对象很有用,但是它不能向现有对象添加属性或方法。
幸运的是,向对象添加新数据就像创建赋值语句一样简单

以下示例创建一个空对象
然后使用赋值语句添加两个属性(海豚和哺乳动物)和方法年。
请注意,此示例使用 点表示法 ,但 括号表示法 也同样有效。

var animal = {};
animal.dolphin = 1;
animal.mammal = null;
animal.years = function() {
  return "I am 5 years()";
};

概括
对象是由基元和其他对象构建的复合数据类型。对象的构建块通常称为其字段或属性。属性用于描述对象的某些方面。例如,属性可以描述列表的长度、狗的颜色或人的出生日期。
因此,JavaScript 对象语法对于理解至关重要,因为它是该语言的基础。
首先,您需要先了解对象,然后才能了解面向对象的编程。

  • 点表示法:当属性名称是有效标识符时使用。
  • 括号表示法:当属性名称是动态的或无效标识符时使用。 这些访问器是 JavaScript 中有效操作对象及其属性的基础。

快乐编码!

版本聲明 本文轉載於:https://dev.to/irenejpopova/property-accessors-2dgk?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • Java 中有效的 @SuppressWarnings 註解警告名稱是什麼?
    Java 中有效的 @SuppressWarnings 註解警告名稱是什麼?
    Java 中的@SuppressWarnings 註解警告名稱@SuppressWarnings 註解應用於程式碼區塊時,會抑制某些類型的編譯器警告。 @SuppressWarnings 註解中可以使用的有效警告名稱會因所使用的 IDE 或編譯器而異。 有效警告名稱列表:以下列表包括Eclipse ...
    程式設計 發佈於2024-11-17
  • 如何在 Java 中繞 x 軸垂直旋轉形狀?
    如何在 Java 中繞 x 軸垂直旋轉形狀?
    圍繞x 軸垂直旋轉形狀提供的代碼演示瞭如何旋轉多邊形,但它不會圍繞x 軸旋轉它x 軸。要實現繞 x 軸的垂直旋轉,我們可以將多邊形旋轉 90 度,然後套用所需的弧度旋轉。修改後的程式碼如下:import java.awt.*; import java.awt.event.*; import java...
    程式設計 發佈於2024-11-17
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-17
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2024-11-17
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-17
  • 如何在不同網頁上儲存 JavaScript 變數?
    如何在不同網頁上儲存 JavaScript 變數?
    跨頁面持久保存 JavaScript 變數在 JavaScript 中,變數的作用域通常僅限於定義它們的頁面。但是,在某些情況下,您可能需要從一個頁面存取另一個頁面的變數。這就是持久化變數的概念發揮作用的地方。 跨頁面持久化 JavaScript 變數的一種方法是利用 window.name 屬性。...
    程式設計 發佈於2024-11-17
  • 如何在多項目 Gradle 配置中包含跨模組的測試依賴關係?
    如何在多項目 Gradle 配置中包含跨模組的測試依賴關係?
    Gradle 中的多項目測試依賴關係Gradle 中的多項目測試依賴關係在Gradle 中使用多項目配置時,管理跨項目測試的依賴關係可能具有挑戰性。本文探討了一個常見問題,即一個模組的測試依賴項在另一個模組中無法識別,並著重於使用者遇到的具體範例。 使用者俱有包含兩個專案 A 和 B 的多專案設定....
    程式設計 發佈於2024-11-17
  • 為什麼在 C++ 中包含“cstdio”時,“printf”可以在沒有“std::”的情況下工作?
    為什麼在 C++ 中包含“cstdio”時,“printf”可以在沒有“std::”的情況下工作?
    cstdio stdio.h 命名空間cstdio stdio.h 命名空間cstdio 的 C 參考聲明「庫的每個元素都在 std 命名空間內定義」。然而,您發現 std::printf 和 printf 都可以工作,這就提出了 C 標頭是否在兩個命名空間中都包含符號的問題。 答案更細緻。 包含 ...
    程式設計 發佈於2024-11-17
  • 使用 WordPress API 的綜合指南:身份驗證和後期調度
    使用 WordPress API 的綜合指南:身份驗證和後期調度
    在本指南中,我們將探討如何使用 WordPress API 進行驗證並安排特定發佈時間的貼文。這些步驟將幫助您以程式設計方式安全地管理您的 WordPress 內容。 使用 WordPress API 進行身份驗證 要安全地與 WordPress API 交互,您需要對您的要求進行...
    程式設計 發佈於2024-11-17
  • 如何在 Java 中將字串轉換為輸入流?
    如何在 Java 中將字串轉換為輸入流?
    Java中將字串轉換為InputStream給定一個字串,可以方便地將其轉換為InputStream物件以進行進一步處理.要實現此目的,可以利用ByteArrayInputStream 類別。此類包裝了一個位元組數組並將其公開為 InputStream。可以使用與所需字串對應的位元組來初始化位元組數...
    程式設計 發佈於2024-11-17
  • 為什麼 Flex 項目不透過邊距和「邊框」大小縮小以適應每行三個?
    為什麼 Flex 項目不透過邊距和「邊框」大小縮小以適應每行三個?
    Flex 項目忽略邊距和邊框大小在Flexbox 中,透過設定flex: 1 1 33.33% 和margin: 10px on flex物品,人們可能會期望每排三個盒子。然而,使用 flex-wrap:wrap 時,盒子不會縮小到每行三個。 原因在於 box-sizing: border-box ...
    程式設計 發佈於2024-11-17
  • 如何在SQL儲存過程中實現真正的動態排序?
    如何在SQL儲存過程中實現真正的動態排序?
    SQL 儲存過程中的動態排序:深入探究在SQL 儲存過程中動態排序的需求是Web 和應用程式中的常見需求Windows 應用程式。然而,有效實現它的問題仍然存在。 現有方法:Hackish 解一種流行的方法涉及複雜的PHP CASE-WHEN 構造,該構造動態分配排序列和基於參數值的方向。雖然這種方...
    程式設計 發佈於2024-11-17
  • Ubuntu 升級後如何解決 Python 中的「ImportError: No module named 'encodings'」?
    Ubuntu 升級後如何解決 Python 中的「ImportError: No module named 'encodings'」?
    解決Ubuntu升級後Python中的「ImportError: No module name 'encodings'」問題無法取得語言環境編碼時出現的問題,導致錯誤訊息「ImportError:沒有名為'encodings'的模組。」儘管重新安裝Python 並設定...
    程式設計 發佈於2024-11-17
  • 簡單工廠
    簡單工廠
    什么是简单工厂? 简单工厂不是设计模式。它只是将对象创建与客户端代码解耦。换句话说,简单工厂通过将实例化逻辑移至单独的类来封装对象实例化。 简单工厂经常与工厂模式混淆。我们将研究简单工厂来阐明它们的区别。另外,学习简单工厂可以帮助我们轻松理解工厂模式。 简单工厂可以...
    程式設計 發佈於2024-11-17
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-17

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3