ES13:类私有属性和方法、顶层 await、at() 方法、Object.hasOwnProperty()、类静态块 相关知识点

系列文章目录

ES6中 对象字面量、解构赋值、var,let ,const、块及作用域、展开运算符与剩余参数相关知识点
ES6中 Map 集合类型知识点、常见使用场景、以及案例
ES6中 Set集合知识点、常见使用场景、以及案例
ES6中 迭代器与生成器,相关知识点、常见使用场景、以及案例
ES6中 Promise 相关知识点、常见使用场景、以及案例
ES6中 箭头函数、this的指向问题

ES7:includes()、指数运算符 详细教程
ES8:async/await、Object 的新静态方法、padStart/padEnd、函数参数列表末尾允许逗号 相关知识点
ES9:对象扩展与剩余参数运算符、异步迭代、Promise新增方法、模板字符串修订 相关知识点
ES10:数组扁平化、对象转换、字符串修剪、catch参数、Symbol描述文字、toString修、sort排序、标准化的globalThis 相关知识点
ES11:可选链操作符、空值合并运算符、allSettled、动态导入、matchAll、meta 相关知识点
ES12:逻辑赋值运算符、数字分隔符、replaceAll、Promise新方法、WeakRef、Setter/Getter 相关知识点
ES13:类私有属性和方法、顶层 await、at() 方法、Object.hasOwnProperty()、类静态块 相关知识点
ES14:数组的新"拷贝并修改"方法、findLast() 和 findLastIndex()、 Symbol 作为 WeakMap 的键 相关知识点
ES15:Object.groupBy() 和 Map.groupBy()、Promise.withResolvers() 相关知识点
ES16:Set 集合方法增强、Promise.try、迭代器助手、JSON 模块导入 相关知识


文章目录


ES13(也被称为 ECMAScript 2022)是一个非常实用的版本,它没有引入那种翻天覆地的语法改变,但解决了很多我们在实际开发中感到"别扭"的痛点。

以下是 ES13 引入的核心新功能及代码示例教学:


一、类私有属性和方法

在 ES13 之前,JavaScript 类没有真正的"私有性",通常用下划线 _变量名 来约定俗成。现在,你可以使用 # 前缀来定义真正的私有成员,外部无法直接访问。

javascript 复制代码
class BankAccount {
  #balance = 0; // 私有属性

  constructor(initialAmount) {
    this.#balance = initialAmount;
  }

  #formatCurrency(amount) { // 私有方法
    return `$${amount}`;
  }

  showBalance() {
    console.log(`当前余额: ${this.#formatCurrency(this.#balance)}`);
  }
}

const account = new BankAccount(1000);
account.showBalance(); // 输出: 当前余额: $1000
// console.log(account.#balance); // 报错:SyntaxError

二、顶层 await (Top-level await)

以前 await 必须写在 async 函数内部。现在,在 ES 模块 的顶层可以直接使用 await。这对于初始化数据库连接或动态加载依赖非常方便。

代码如下(示例):

javascript 复制代码
// 以前需要写在一个立即执行的 async 函数里
// 现在直接写:
const dynamicData = await fetch('https://api.example.com/data');
const json = await dynamicData.json();

export const data = json;

三、at() 方法

这是针对数组和字符串的一个"小而美"的更新。它允许你通过 负索引 轻松获取末尾元素。

javascript 复制代码
const arr = [10, 20, 30, 40];

// 以前获取最后一位:
console.log(arr[arr.length - 1]); // 40

// 现在使用 at():
console.log(arr.at(-1)); // 40
console.log(arr.at(-2)); // 30

四、 Object.hasOwnProperty()

它是 Object.prototype.hasOwnProperty() 的更安全、更简洁的替代方案。它不会因为对象原型被修改(或者对象是 null)而报错。

javascript 复制代码
const obj = { name: 'Gemini' };

// 推荐写法:
console.log(Object.hasOwnProperty(obj, 'name')); // true
console.log(Object.hasOwnProperty(obj, 'age'));  // false

五、类静态块 (Class Static Block)

如果你需要在类加载时进行复杂的静态初始化逻辑(例如逻辑中包含 try...catch),可以使用静态块

javascript 复制代码
class Config {
  static connection;
  static {
    try {
      this.connection = 'Success';
    } catch {
      this.connection = 'Fail';
    }
  }
}
相关推荐
xyq20241 天前
Vue.js 实例
开发语言
敲代码的瓦龙1 天前
Android?碎片!!!
java·开发语言·android-studio
froginwe111 天前
SVG 滤镜:全面解析与高效应用
开发语言
枫叶丹41 天前
【HarmonyOS 6.0】Data Augmentation Kit端侧问答模型:本地化智能问答的技术演进
开发语言·华为·harmonyos
醉舞经阁半卷书11 天前
LangGraph详解
开发语言·人工智能·python·深度学习·机器学习·自然语言处理
geovindu1 天前
go:Condition Variable Pattern
开发语言·后端·设计模式·golang·条件变量模式
晓得迷路了1 天前
栗子前端技术周刊第 128 期 - Rolldown 1.0、Vitest、Node.js 26.0.0...
前端·javascript·css
时光追逐者1 天前
一款基于 C# 开发的 Windows 10/11 系统增强工具,精简、优化、定制一站完成!
开发语言·windows·c#·.net
测试员周周1 天前
【AI测试功能6】功能测试的自动化率:哪些该自动、哪些必须人工——AI测试人机协作决策指南
开发语言·人工智能·python·功能测试·单元测试·自动化·测试用例
qingy_20461 天前
浏览器页面出现竖向滚动条的解决方案
前端·javascript·vue.js