ES11 全新的 private 字段:更好的代码封装

阅读时长 3 分钟读完

在 JavaScript 中,对于对象属性的访问权限管理一直是一个难题。传统的方式是使用下划线作为属性名称的前缀表示该属性为私有属性,但这只是一种变相的约定,并没有真正实现数据和行为的封装。ES6 引入了类和模块的概念,进一步增强了封装性,但仍然存在问题。ES11 引入了私有字段的概念,对封装性做出了重大贡献。

什么是私有字段

私有字段是指仅能在某个类的内部访问的字段。它与类的私有属性不同,私有属性是无法在子类中被继承的,而私有字段则是可以被子类继承的。私有字段的命名以 # 为前缀,与 this.#name 这样的语法形式一起构成了私有字段的基本语法。

为什么需要私有字段

私有字段的最大用处在于数据和行为的封装。JavaScript 中函数没有访问权限的概念,类中的方法可以随意访问该类的所有属性。如果该类的属性被公开,那么就无法避免在某个不正常的操作下改变该属性的值,导致不可预估的结果。私有字段的存在则使得该类的状态只能通过其公共方法进行修改,有效保证了数据一致性。

如何使用私有字段

私有字段的使用只需要在字段名前加上 # 即可。例如:

-- -------------------- ---- -------
----- ------ -
  ------

  ----------------- -
    ---------- - -----
  -

  ------- -
    ------------------- -- ---- -- ----------------
  -
-

----- ------ - --- --------------
--------------- -- ------ -- ---- -- ---
-------------------------- -- ----------- ------------ ------- ----- ------- ---- -- -------- -- -- --------- -----

上述代码中,我们定义了一个 Person 类,并在其内部定义了一个私有字段 #name。该字段在类的构造函数中被初始化,可以在其私有方法 greet 中使用。如果在类外直接访问该私有字段,就会遭遇编译错误。

私有字段与继承

私有字段可以被子类继承,但注意不是继承了该字段的值,而是继承了该字段本身的结构。例如:

-- -------------------- ---- -------
----- ------ -
  ------

  ----------------- -
    ---------- - -----
  -

  ------- -
    ------------------- -- ---- -- ----------------
  -
-

----- --- ------- ------ -
  ------ -
    ------------------ --------
  -
-

----- --- - --- ---------------
------------ -- ------ -- ---- -- -------

上述代码中,我们定义了一个 Animal 类,并在其内部定义了私有字段 #name。然后我们定义了一个 Dog 类,继承自 Animal 类。在子类中不能通过 super 访问父类的私有字段,因此不能直接访问 #name 属性,但是可以调用继承来的父类方法 hello,进而调用父类中 #name 属性的值。

总结

私有字段的引入使得 JavaScript 中的封装性更加完善,代码更加安全和可靠。但它只是一个语言特性,正确使用它需要程序员自己保证代码的正确性和规范性。私有字段将推动 JavaScript 生态圈更加规范、健康发展,为前端开发者提供更多更好的选择。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/646b0442968c7c53b0a76908

纠错
反馈