ES6深潜指南:解锁JavaScript类与继承的高级技巧,让您的代码更加优雅

前言

随着前端技术的迅猛发展,JavaScript已经成为构建现代Web应用不可或缺的编程语言。ES6(ECMAScript
2015)引入了许多期待已久的特性,其中类(Classes)和继承机制的引入,极大地增强了JavaScript的面向对象编程能力。本文将深入探讨JavaScript中类和继承的高级技巧,以及如何在实际开发中应用这些技巧,从而提升代码的可读性和可维护性。

在这里插入图片描述

一、JavaScript类的引入

在ES6之前,JavaScript没有类的概念,而是通过构造函数和原型链来模拟类和继承。现在,我们可以用更自然的方式定义类了。

class Person {
  constructor(name) {
    this.name = name;
  }

  sayHello() {
    return `Hello, my name is ${this.name}`;
  }
}

const person = new Person('Alice');
console.log(person.sayHello()); // 输出: Hello, my name is Alice

二、继承的实现

通过extends关键字,JavaScript正式引入了类的继承机制。子类可以继承父类的属性和方法,也可以对其进行扩展。

class Programmer extends Person {
  constructor(name, language) {
    super(name); // 调用父类的constructor
    this.language = language;
  }

  code() {
    return `I am coding in ${this.language}`;
  }
}

const programmer = new Programmer('Bob', 'JavaScript');
console.log(programmer.code()); // 输出: I am coding in JavaScript
console.log(programmer.sayHello()); // 输出: Hello, my name is Bob

三、使用static关键字定义静态方法

要在类中定义静态(类)方法,我们可以使用static关键字。这些方法直接属于类本身,而不是类的实例。

class Utility {
  static sayHi() {
    return 'Hi there!';
  }
}

console.log(Utility.sayHi()); // 直接调用类的静态方法

四、使用getset定义属性的访问器

ES6允许我们为类的属性定义getter和setter,这样我们可以控制属性的访问和赋值行为。

class Temperature {
  constructor(celsius) {
    this.celsius = celsius;
  }

  get fahrenheit() {
    return this.celsius * 9 / 5 + 32;
  }

  set fahrenheit(value) {
    this.celsius = (value - 32) * 5 / 9;
  }
}

const temp = new Temperature(28);
console.log(temp.fahrenheit); // 输出: 82.4
temp.fahrenheit = 100;
console.log(temp.celsius); // 输出: 37.77777777777778

五、使用Symbol实现私有属性

虽然JavaScript中没有真正的私有属性,通过Symbol我们可以实现类似的功能。

const _privateVar = Symbol('private symbol');

class SecretKeeper {
  constructor() {
    this[_privateVar] = 'I am only known by me';
  }

  getSecret() {
    return this[_privateVar];
  }
}

const secrets = new SecretKeeper();
console.log(secrets.getSecret()); // 输出: I am only known by me

六、实践案例

案例1:基本继承的实现

在构建电商系统时,商品类(Product)和电子产品类(Electronics)之间的继承关系。

class Product {
  constructor(name, price) {
    this.name = name;
    this.price = price;
  }
}

class Electronics extends Product {
  constructor(name, price, brand) {
    super(name, price);
    this.brand = brand;
  }

  showBrand() {
    return `Brand: ${this.brand}`;
  }
}

const phone = new Electronics('iPhone', 5999, 'Apple');
console.log(phone.showBrand()); // 输出: Brand: Apple

案例2:使用静态方法作为工具函数

在构建数据处理工具时,可以使用静态方法来封装通用功能。

class DataHandler {
  static uniqueItems(array) {
    return [...new Set(array)];
  }
}

const items = [1, 2, 2, 3, 4, 4];
console.log(DataHandler.uniqueItems(items)); // 输出: [1, 2, 3, 4]

案例3:使用访问器控制属性

在构建用户模型时,可以使用访问器来隐藏数据的内部表示。

class User {
  constructor(username) {
    this.username = username;
  }

  get password() {
    return 'Your password is hidden';
  }

  set password(pass) {
    this._password = pass; // 内部存储密码
  }
}

const user = new User('jsmith');
console.log(user.password); // 输出: Your password is hidden
user.password = 'password123';

案例4:使用Symbol实现类的私有方法

在构建技术栈管理器时,可以使用Symbol来实现类的私有方法。

const _privateMethod = Symbol('private method');

class StackManager {
  constructor() {
    this.stack = [];
    this[_privateMethod] = this._log;
  }

  push(item) {
    this.stack.push(item);
    this[_privateMethod]();
  }

  _log() {
    console.log('Stack updated:', this.stack);
  }
}

const manager = new StackManager();
manager.push('Vue');
// 输出: Stack updated: ['Vue']

七、总结

ES6中类和继承的引入,为JavaScript带来了面向对象编程的强大功能。通过合理利用这些特性,我们能够写出更加优雅和高效的代码。本文通过多个实践案例,演示了类、继承、静态方法、访问器和Symbol的使用方法,希望能够帮助前端开发者更好地掌握这些高级技巧,提升代码质量,优化开发体验。


以上就是对JavaScript类与继承高级技巧的探讨,希望对大家有所启发。在未来的技术迭代中,我们还需要不断学习和实践,将最新技术与实践经验相结合,为Web应用开发贡献更多创新和解决方案。

码克疯v1 | 技术界的疯狂探索者 | 在代码的宇宙中,我是那颗永不满足的探索星。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/746885.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

gc.log中 CMS-concurrent-abortable-preclean

问题 在gc日志中看到 2024-06-26T16:16:07.5040800: 64690272.666: [CMS-concurrent-abortable-preclean-start]CMS: abort preclean due to time 2024-06-26T16:16:12.5530800: 64690277.716: [CMS-concurrent-abortable-preclean: 1.052/5.049 secs] [Times: user1.33 sys0…

Gradle学习-3 Gradle构建的生命周期

Gradle常用文件目录 Gradle 构建的生命周期,有3个阶段: 初始化阶段配置阶段执行阶段 1、初始化阶段 Gradle 支持构建单个工程个多个子工程,初始化阶段主要负责收集所有参与本次构建的子工程,创建一个项目的层次结构,并未每个…

喜报!极限科技新获得一项国家发明专利授权:“搜索数据库的正排索引处理方法、装置、介质和设备”

近日,极限数据(北京)科技有限公司(简称:极限科技)新获得一项国家发明专利授权,专利名为 “搜索数据库的正排索引处理方法、装置、介质和设备”,专利号:ZL 2024 1 0479400…

实用软件下载:BetterZip 5最新安装包及详细安装教程

​我们都知道BetterZip是Mac平台上非常受欢迎的文件“解/压缩”工具之一,并且能够生成被Win支持的压缩包。不同领域的应用证明了这是一款功能强大的 Mac 解压缩软件支持 RAR、ZIP等30 种档案格式,可创建小型应用软件。值得一提的是而且能够在不必解压的情…

【教学类-64-05】20240625彩棒鱼骨图(二)AB排列 6.5*1CM 6选2根 30种

背景需求: 【教学类-64-04】20240619彩棒鱼骨图(一)6.5*1CM 6根棒子720种-CSDN博客文章浏览阅读897次,点赞23次,收藏13次。【教学类-64-04】20240619彩棒鱼骨图(一)6.5*1CM 6根棒子720种https:…

WordPress强大多功能主题模板The7 v9.16.0

模板介绍 The7可以与WPBakery Page Builder(原Visual Composer)和Ultimate Addons的完全无缝集成。它也与大多数流行的插件完全兼容,例如WooCommerce,WPML,Yoast SEO,All in One WP Migration,…

视觉分割的定义与性能度量

文章目录 视觉分割的定义语义分割(Semantic Segmentation)实例分割(instance Segmentation)全景分割(Panoptic Segmentation)视频语义分割(Video Semantic Segmentation)视频实例分割(Video instance Segmentation)视频全景分割(Video Panoptic Segmentation)各任务对比 视觉分…

classnames.js 优化类名的工具库

classnames.js 是什么? classnames.js 是一个简单的类名控制工具库,可以方便的通过条件动态控制class类名的显示。 官方代码及示例文档参见:GitHub - JedWatson/classnames: A simple javascript utility for conditionally joining classNames together 为什么要使用 clas…

Linux扩展lvm分区实践 -- 使用其他磁盘的空间

如图,根分区900G,计划将另一块磁盘sdb分出1T来给根分区 步骤 1:创建新的分区 sudo fdisk /dev/sdb输入 n 创建一个新分区 然后选择分区类型,输入p 设置起始扇区(默认),然后设置分区大小&…

服务器部署与DDOS攻防

知识点:DHPC与Web服务部署,DHCPig攻防,SYN Flooding测试 DHCP: 能够自动为客户机获取IP等参数 DHCP是动态主机配置协议(Dynamic Host Configuration Protocol)的缩写,它是一种网络管理协议&am…

633. 平方数之和(中等)

633. 平方数之和 1. 题目描述2.详细题解3.代码实现3.1 Python3.2 Java内存溢出溢出代码正确代码与截图 1. 题目描述 题目中转:633. 平方数之和 2.详细题解 本题是167. 两数之和 II - 输入有序数组(中等)题目的变型,由两数之和变…

PS系统教程30

图层蒙版组合使用 案例介绍 全选背景图-复制背景图粘贴背景图CtrlI反选背景色填充黑色快速选区工具框柱需要素材画笔涂抹白色 步骤截图 1-3 4-5 图层蒙版与渐变工具结合使用 案例2 注意 使用PS的渐变工具覆盖全部的原因可能包括操作不当或设置错误。 操作不当&#xff1…

docker入门配置

1、创建配置镜像 由于国内docker连接外网速度慢,采用代理 vi /etc/docker/daemon.json添加以下内容 {"registry-mirrors": ["https://9cpn8tt6.mirror.aliyuncs.com","https://dockerproxy.com","https://hub-mirror.c.163.co…

Opencv中RotatedRect和ellipse的角度方向

版本:opencv-4.7.0-windows Opencv中,大多数时候,逆时针旋转是正方向,但在RotatedRect和ellipse中,顺时针旋转是正方向。 //RotatedRect的角度参数是顺时针为正方向 RotatedRect(const Point2f& center, const Si…

鸿蒙开发Ability Kit(程序框架服务):【FA模型切换Stage模型指导】 app和deviceConfig的切换

app和deviceConfig的切换 为了便于开发者维护应用级别的属性配置,Stage模型将config.json中的app和deviceConfig标签提取到了app.json5中进行配置,并对部分标签名称进行了修改,具体差异见下表。 表1 配置文件app标签差异对比 配置项FA模型…

交通大数据分析与挖掘实训【对提供的CSV格式数据使用pandas库分析-Matplotlib库绘图】

背景: 《交通大数据分析与挖掘》实训 指 导 书 编著 二○二四年五月 一、实训目的 1、掌握python开发环境(如Anaconda)及Numpy等常见第三方库的使用; 2、熟悉Anaconda在线编程平台,学会基本的python程序编写…

企业邮箱客服响应速度哪家好?

在选择企业邮箱的过程中,有一个点很容易被忽略,那就是企业邮箱客服的响应速度。试想,若是出现了邮件发件问题,而不能及时解决处理,可能会给企业带来很大的经济损失。今天就来对比下国内外三款企业邮箱的客服响应速度。…

typescript学习回顾(三)

今天继续来分享ts的相关概念,枚举,ts模块化,接口和类型兼容性 ts的扩展类型:类型别名,枚举,接口和类 枚举 基础概念 枚举通常用于约束某个变量的取值范围。当然字面量和联合类型配合使用,也可…

电脑开机之后屏幕没有任何显示?怎么检查?

前言 最近有很多小伙伴来咨询,自己的电脑开机之后,屏幕真的是一点显示都没有,只有CPU风扇在转。 这个情况小白经常经常经常遇到,所以写一篇关于这个问题的排查教程。按照这个教程来排查,除非真的是硬件损坏&#xff…

武汉星起航:挂牌上海股权交易中心,自营店铺销售额迎飞跃式增长

2023年10月30日,对于武汉星起航电子商务有限公司而言,无疑是一个载入史册的重要日子。这一天,公司成功在上海股权托管交易中心挂牌展示,正式登陆资本市场,开启了全新的发展篇章。这一里程碑式的跨越,不仅彰…