」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 升級你的 JS:物件文字增強將改變你的程式碼

升級你的 JS:物件文字增強將改變你的程式碼

發佈於2024-11-06
瀏覽:357

Level Up Your JS: Object Literal Enhancements That Will Change Your Code

对象字面量是 JavaScript 的基本组成部分,使我们能够快速创建和初始化对象。在 ES6 及更高版本中,JavaScript 引入了对对象字面量的多项增强,使它们更加强大和简洁。让我们深入研究这些改进,看看它们如何使我们的代码更干净、更高效。

1. 属性简写名称

创建对象时,如果属性名称与分配给它的变量名称相同,则可以使用简写语法。

const name = 'John';
const age = 30;

// Old way
const person = {
    name: name,
    age: age
};

// New way
const person = { name, age };

console.log(person); // { name: 'John', age: 30 }

这种简写语法减少了重复并使我们的代码更加简洁。
MDN 文档:对象初始值设定项

2. 简写方法名称

同样,在对象中定义方法时,我们可以省略function关键字和冒号。

// Old way
const calculator = {
    add: function(a, b) {
        return a   b;
    }
};

// New way
const calculator = {
    add(a, b) {
        return a   b;
    }
};

console.log(calculator.add(5, 3)); // 8

这种语法更清晰、更容易阅读,特别是当一个对象中有多个方法时。
MDN 文档:方法定义

3. 计算属性名称

ES6 允许我们使用表达式来计算属性名称。当您想要创建动态属性名称时,这特别有用。

const prefix = 'user_';
const id = 1234;

const user = {
    [`${prefix}${id}`]: 'John Doe'
};

console.log(user.user_1234); // 'John Doe'

当您需要根据某些逻辑或外部数据创建具有动态键的对象时,此功能非常强大。
MDN 文档:计算属性名称

4. 方法属性

ES6 引入了一种使用 get 和 set 关键字在对象字面量中定义方法的新方法。这允许您创建计算属性而无需显式调用函数。

const person = {
    firstName: 'John',
    lastName: 'Doe',
    get fullName() {
        return `${this.firstName} ${this.lastName}`;
    },
    set fullName(name) {
        [this.firstName, this.lastName] = name.split(' ');
    }
};

console.log(person.fullName); // 'John Doe'
person.fullName = 'Jane Smith';
console.log(person.firstName); // 'Jane'
console.log(person.lastName); // 'Smith'

获取器和设置器提供了一种定义计算属性的简洁方法,可用于在获取或设置值时添加验证或副作用。
MDN 文档:Getter 和 Setter

5. 对象扩展运算符

虽然扩展运算符 (...) 严格来说不是对象字面量增强的一部分,但它是一个强大的功能,可以很好地与对象字面量配合使用。它允许您轻松克隆对象或合并多个对象。

const defaults = {
    theme: 'light',
    fontSize: 14
};

const userPreferences = {
    fontSize: 16
};

const settings = {
    ...defaults,
    ...userPreferences
};

console.log(settings); // { theme: 'light', fontSize: 16 }

扩展运算符可以轻松地基于现有对象创建新对象,这对于维护应用程序中的不变性特别有用。
MDN 文档:扩展语法 (...)

结论

JavaScript 中的这些对象字面量增强功能为开发人员提供了更具表现力和简洁的方法来处理对象。通过利用这些功能,您可以编写更清晰、更易读且更易于维护的代码。

请记住,虽然这些功能很强大,但明智地使用它们也很重要。始终优先考虑代码的可读性和可维护性而不是简洁性。


浏览器兼容性

以下是浏览器对这些功能的支持的快速概述:

特征 铬合金 火狐浏览器 Safari 边缘
简写属性 43 33 9 12
速记方法 43 34 9 12
计算属性名称 43 34 8 12
Getter/Setter 方法 1 1.5 3 12
对象传播 60 55 11.1 79

实际用例

  1. 速记属性:非常适合从现有变量创建对象,特别是在 React 组件 props 中。
  2. 简写方法:在类结构或定义多个相关函数时很有用。
  3. 计算属性名称:非常适合在国际化 (i18n) 对象中创建动态键。
  4. Getter/Setter 方法:非常适合创建具有内置验证或副作用的“智能”属性。
  5. Object Spread:非常适合 Redux 中的状态管理或通过轻微修改创建新对象。

性能考虑因素

虽然这些增强功能通常不会产生显着的性能影响,但对象扩展运算符在合并许多属性时可能比 Object.assign() 效率低。对于大多数用例,可读性的好处超过了任何微小的性能差异。

相关功能

为了进一步增强您对现代 JavaScript 对象操作的理解,请考虑探索:

  • 解构赋值
  • Object.assign() 方法
  • Object.entries()、Object.values() 和 Object.keys() 方法
  • 用于对象不变性的 Object.freeze() 和 Object.seal() 方法

通过掌握这些对象文字增强功能和相关功能,您将能够编写更优雅、更高效的 JavaScript 代码。

如果您觉得本文有帮助,请单击“关注”按钮以获取有关 JavaScript、Reactjs 和 Next.js 的更多更新和有用资源。您还可以在 Twitter @OgDev-01 上关注我,获取有用的资源和技术趋势,或者在 OpenSauced 上关注我所做的贡献以及我强调的贡献!

版本聲明 本文轉載於:https://dev.to/og_dev/level-up-your-js-object-literal-enhancements-that-will-change-your-code-jbc?1如有侵犯,請聯絡study_golang@163 .com刪除
最新教學 更多>
  • 如何根據 Python 中的條件取代清單中的值?
    如何根據 Python 中的條件取代清單中的值?
    Python 中根據條件替換清單中的值在Python 中,您可能會遇到需要操作清單中元素的情況清單,例如根據特定條件替換值。透過利用有效的技術,您可以有效地執行這些修改。 一種方法涉及利用列表理解。例如,如果您有一個列表[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 並且想要替...
    程式設計 發佈於2024-11-06
  • 如何使用 Docker Scratch 在 Golang 中建立靜態二進位檔案:CGO_ENABLED=0 和 -ldflags?
    如何使用 Docker Scratch 在 Golang 中建立靜態二進位檔案:CGO_ENABLED=0 和 -ldflags?
    在Golang 中建立靜態二進位檔案的標誌當使用Docker 暫存庫在Golang 中建立靜態二進位檔案時,必須包含CGO_ENABLED =0 和-ldflags '-extldflags "-static"' 標誌。雖然這兩個選項可能看起來多餘,但它們在實現靜...
    程式設計 發佈於2024-11-06
  • 我可以將行追加到 CSV 檔案而不覆蓋它嗎?
    我可以將行追加到 CSV 檔案而不覆蓋它嗎?
    在Python 中向現有CSV 檔案追加新行:一種更有效的方法當您需要使用附加行更新CSV文件時,您可能會考慮以下問題:問: 是否可以向現有CSV 文件添加新行,而無需覆蓋和重新創建文件? 答: 絕對!以下是將行追加到 CSV 檔案的更有效方法:您可以利用Python 中的 with 語句。 以下程...
    程式設計 發佈於2024-11-06
  • Nestjs、Firebase、GCloud。如何在 TypeScript 中快速設定 API 後端。
    Nestjs、Firebase、GCloud。如何在 TypeScript 中快速設定 API 後端。
    It's great that you decided to open this article. My name is Fedor, and I've been a full-stack developer on a permanent basis since the end of 2021. J...
    程式設計 發佈於2024-11-06
  • 如何在維護非同步操作的同時避免鍊式函數中的 jQuery Promise?
    如何在維護非同步操作的同時避免鍊式函數中的 jQuery Promise?
    在鍊式函數中迴避jQuery Promise儘管建議避免jQuery Promise,但開發人員在不使用jQuery 的情況下鏈接非同步jQuery 函數時可能會面臨挑戰Promise 處理機制,如.then() 或.when()。為了解決這個問題,請考慮以下方法:jQuery Promise 可以...
    程式設計 發佈於2024-11-06
  • 為什麼「repr」方法在 Python 中至關重要?
    為什麼「repr」方法在 Python 中至關重要?
    探討repr方法的意義在Python程式設計的脈絡中,repr 方法在將物件表示為字串方面起著關鍵作用。這種簡潔而詳細的表示有多種用途:repr的目的方法:repr的主要目標方法的目的是傳回一個物件的字串表示形式,該物件既是人類可讀的,而且重要的是,是明確的。這種表示法應該足以重新建立具有相同狀態和...
    程式設計 發佈於2024-11-06
  • 每個開發人員都應該了解可擴展和高效應用程式的頂級 React 設計模式
    每個開發人員都應該了解可擴展和高效應用程式的頂級 React 設計模式
    隨著 React 繼續主導前端生態系統,掌握其設計模式可以顯著提高應用程式的效率和可擴展性。 React 設計模式提供了組織和建置元件、管理狀態、處理 props 和提高可重複使用性的最佳實踐。在本部落格中,我們將探討一些關鍵的 React 設計模式,這些模式可以讓您的開發流程從優秀走向卓越。 ...
    程式設計 發佈於2024-11-06
  • 在 React 中建立無限滾動元件
    在 React 中建立無限滾動元件
    介绍 我们在应用程序和网页中看到无限滚动,尤其是希望我们滚动的社交媒体。虽然无意识地滚动不好,但构建自己的无限滚动是很棒的。作为开发人员,我们应该尝试重新创建我们在网上冲浪时看到的组件。它可以挑战您在实现某些组件时了解更多信息并跳出框框进行思考。 此外,如果您希望在应用程序中实现无...
    程式設計 發佈於2024-11-06
  • 在 React 中建立響應式會議圖塊的動態網格系統
    在 React 中建立響應式會議圖塊的動態網格系統
    In the era of remote work and virtual meetings, creating a responsive and dynamic grid system for displaying participant video tiles is crucial. Inspi...
    程式設計 發佈於2024-11-06
  • 使用 Spring Boot 和 Spring Cloud 開發微服務
    使用 Spring Boot 和 Spring Cloud 開發微服務
    微服務架構已成為建構可擴展和模組化系統的流行解決方案。透過微服務,您可以將單一應用程式分解為更小的、獨立的和專業的服務,這使得系統的維護和發展變得更加容易。在這篇文章中,我們將探討如何使用 Spring Boot 和 Spring Cloud 來創造健壯且有效率的微服務。 微服務簡介 微服務背後的...
    程式設計 發佈於2024-11-06
  • 克服 PHP DOM XML 解析中的挑戰:問題與解決方案
    克服 PHP DOM XML 解析中的挑戰:問題與解決方案
    簡化PHP DOM XML 解析:揭開要點當您瀏覽PHP DOM 函數的複雜性時,可能會出現某些障礙。為了解決這些挑戰,讓我們開始了解 DOM 的複雜性,並找出常見問題的解決方案。 問題1:使用xml:id 馴服ID當使用ID 來防止樹中出現重複頁面時,PHP 的DOM 遇到了一個難題:getEle...
    程式設計 發佈於2024-11-06
  • 密碼重設功能:使用 OTP 重設密碼
    密碼重設功能:使用 OTP 重設密碼
    後端 2. 重設密碼 轉向下一個 API。 PUT 上 /api/reset-password, req -> otp, email, 新密碼, res -> nocontent // controllers/passwordReset.go func Reset...
    程式設計 發佈於2024-11-06
  • 如何從全域站點套件繼承 Virtualenv 中的特定套件?
    如何從全域站點套件繼承 Virtualenv 中的特定套件?
    從全域網站套件繼承Virtualenv 中的特定套件為了增強虛擬環境(virtualenv) 的功能,您可能會想要從全域網站繼承特定套件網站套件目錄。這種方法允許您選擇性地將重要的程式庫合併到您的 virtualenv 中,而無需直接安裝它們。 繼承方法要實現這種繼承,請使用以下命令建立新的virt...
    程式設計 發佈於2024-11-06
  • 如何解決 EF6 中的“找不到 'MySql.Data.MySqlClient\'\”錯誤?
    如何解決 EF6 中的“找不到 'MySql.Data.MySqlClient\'\”錯誤?
    MySQL 實體框架的提供者註冊使用MySQL 和實體框架時,您可能會遇到錯誤「找不到Entity Framework提供者” 'MySql.Data.MySqlClient' ADO.NET 提供者。 「儘管安裝了最新的MySQL 連接器,您可能仍然會遇到此問題。出現此問題的原因是...
    程式設計 發佈於2024-11-06
  • 如何利用PHP防止郵件傳輸中的惡意輸入?
    如何利用PHP防止郵件傳輸中的惡意輸入?
    保護電子郵件傳輸的使用者輸入在PHP 中,必須在發送電子郵件之前清理使用者輸入,以防止惡意或有害內容外洩你的系統。考慮下面的簡單 PHP 郵件腳本的程式碼片段:<?php $to = "[email protected]"; $name = $_POST['name']; ...
    程式設計 發佈於2024-11-06

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

Copyright© 2022 湘ICP备2022001581号-3