面向对象编程_javascript类与继承

JavaScript中的class是基于原型的语法糖,通过class定义类并用constructor初始化实例,方法挂载于原型;使用extends实现继承,子类需调用super()初始化父类,支持方法重写;static定义静态方法供类直接调用;#开头的私有字段限制外部访问,提升封装性

面向对象编程_javascript类与继承

JavaScript 中的面向对象编程(OOP)基于原型(prototype),但 ES6 引入了 class 语法,让开发者可以用更清晰、更接近传统语言的方式来创建对象和实现继承。虽然 class 在 JavaScript 中是“语法糖”,其底层仍是基于原型机制,但使用它可以让代码结构更清晰、更易维护。

JavaScript 类的基本语法

使用 class 关键字可以定义一个类。类中通常包含一个 constructor 方法用于初始化实例属性,以及其它方法定义对象行为。

示例:

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

sayHello() {console.log(你好,我是${this.name},今年${this.age}岁。);}}

const p1 = new Person("小明", 25);p1.sayHello(); // 输出:你好,我是小明,今年25岁。

在这个例子中,Person 是一个类,constructor 构造函数在使用 new 创建实例时自动调用,sayHello 是原型上的方法,所有实例共享。

类的继承:extends 与 super

JavaScript 支持通过 extends 实现类的继承,子类可以继承父类的属性和方法。在子类构造函数中,必须先调用 super() 来调用父类的构造函数。

立即学习“Java免费学习笔记(深入)”;

示例:

class Student extends Person {  constructor(name, age, grade) {    super(name, age); // 调用父类构造函数    this.grade = grade;  }

study() {console.log(${this.name} 正在学习,年级是 ${this.grade}。);}

// 可以重写父类方法sayHello() {console.log(我是学生 ${this.name},今年${this.age}岁,读 ${this.grade} 年级。);}}

const s1 = new Student("小红", 20, "大三");s1.sayHello(); // 覆盖后的方法s1.study(); // 子类特有方法

这里 Student 继承了 Person 的所有功能,并扩展了自己的属性和方法。通过 super() 确保父类正确初始化,这是子类构造函数中的必要步骤。

静态方法与私有字段(可选)

类中还可以定义静态方法,它们属于类本身而不是实例,通过 static 关键字声明。

class MathUtils {  static add(a, b) {    return a + b;  }}

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

静态方法常用于工具函数或不需要实例化的操作。

现代 JavaScript 还支持私有字段(以 # 开头),限制外部访问:

class BankAccount {  #balance = 0;

deposit(amount) {this.#balance += amount;}

getBalance() {return this.#balance;}}

const account = new BankAccount();account.deposit(100);console.log(account.getBalance()); // 100// account.#balance; // 错误:无法访问私有字段

总结

JavaScript 的 class 提供了一种更直观的方式来组织面向对象的代码。通过 class 定义模板,用 extends 实现继承,配合 super 调用父类逻辑,再加上静态方法和私有字段的支持,使得 JS 的 OOP 更加完整和安全。尽管底层仍是原型链,但 class 让开发体验更接近传统面向对象语言。

基本上就这些,掌握好类与继承,能让你写出结构清晰、易于扩展的 JavaScript 应用。不复杂但容易忽略的是 super 的调用时机和私有字段的命名规则。

以上就是面向对象编程_javascript类与继承的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1541260.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 13:10:36
下一篇 2025年12月21日 13:10:41

相关推荐

  • 深入理解JavaScript递归函数中的返回值传递机制

    本教程探讨javascript递归函数中返回值丢失的常见问题。当递归调用未显式地将内部调用的返回值向上层传递时,外部调用将收到`undefined`。通过在递归调用前添加`return`关键字,确保返回值沿调用栈正确传递,从而解决在`console.log`中无法捕获最终返回值的问题。 引言:Jav…

    2025年12月21日
    000
  • Mongoose聚合管道:实现高效字符串匹配与数据过滤

    本教程详细介绍了如何在mongoose聚合管道中高效地执行字符串匹配与数据过滤。通过结合`$group`、`$match`聚合阶段与`$regex`查询操作符,实现对聚合结果的服务器端、大小写不敏感的模糊搜索,从而优化性能并避免在应用层进行数据过滤。 引言与挑战 在开发数据驱动的应用时,搜索功能是不…

    2025年12月21日
    000
  • JavaScriptES6新特性_JavaScript语法升级指南

    ES6引入let/const实现块级作用域、禁止重复声明与暂时性死区,解决var的变量提升问题;通过解构赋值从数组或对象中按模式提取数据;使用模板字符串以反引号包裹并嵌入${}表达式,支持多行文本与变量拼接;箭头函数简化语法并词法绑定this,避免回调中this指向丢失,提升代码简洁性与可维护性。 …

    2025年12月21日
    000
  • JavaScript中什么是原始类型_存储方式区别

    JavaScript原始类型共7种,均存于栈中,赋值时复制值本身;引用类型数据存于堆中,栈中仅存地址,赋值时复制地址。 JavaScript 中的原始类型(Primitive Types)是语言最基础的不可变数据单元,共 7 种:Number、String、Boolean、Undefined、Nul…

    2025年12月21日
    000
  • JavaScript构建工具_javascript自动化

    主流JavaScript构建工具包括Webpack、Vite、Rollup、Parcel及Grunt/Gulp,分别适用于复杂项目、现代前端、库打包、快速原型和任务自动化,核心功能涵盖代码转换、模块打包、资源优化等,选型需根据项目类型匹配,目标是提升开发效率与构建可靠性。 JavaScript开发中…

    2025年12月21日
    000
  • JavaScript中什么是生成器_yield关键字作用

    生成器是用function*声明的可暂停恢复执行的特殊函数,通过yield实现惰性求值与双向通信,返回可迭代对象,常用于异步流程控制、按需数据生成及状态机实现。 生成器(Generator)是 JavaScript 中一种特殊的函数,它能**暂停和恢复执行**,配合 yield 关键字使用,让函数变…

    2025年12月21日
    000
  • JavaScript模块加载原理_javascript工程化

    JavaScript模块化经历从全局变量到ESM的演进,通过CommonJS、AMD、UMD逐步完善,最终ESM成为标准,支持静态分析、依赖优化与动态加载,结合打包工具实现高效工程化管理。 JavaScript 模块化不是一开始就有的,早期的 JS 代码都是直接写在 script 标签里,变量全局暴…

    2025年12月21日
    000
  • JavaScript中Set和Map是什么_使用场景

    Set 和 Map 是 JavaScript 中为特定数据管理需求设计的高效、语义清晰的内置集合类型:Set 用于存储唯一值并自动去重,Map 则支持任意类型键值对且保留插入顺序。 Set 和 Map 是 JavaScript 中两种内置的集合类型,它们不是数组或对象的替代品,而是为特定数据管理需求…

    2025年12月21日
    000
  • JavaScriptPolyfill编写_JavaScript兼容性处理

    Polyfill是一段兼容代码,用于在旧浏览器中实现现代JavaScript功能。它通过检测缺失的API并提供替代实现来填补功能空白,如为IE添加Array.prototype.includes支持。与Babel仅转译语法不同,Polyfill专门补全未实现的全局对象或原型方法。编写时需先判断功能是…

    2025年12月21日
    000
  • javascript_如何实现动画效果

    JavaScript实现动画的核心是随时间改变元素样式。1. 使用requestAnimationFrame可实现流畅动画,如让元素平滑移动;2. 通过递增opacity并结合requestAnimationFrame实现淡入效果;3. 结合CSS transition能简化逻辑,适合简单交互动画;…

    2025年12月21日
    000
  • 模板引擎原理_javascript渲染技术

    模板引擎通过解析语法将数据与模板结合生成HTML,提升开发效率。首先分析词法和语法构建AST,或用正则替换变量;再编译为可执行render函数,接收数据输出字符串;最后结合响应式系统实现数据变化自动重渲染,优化DOM操作。 模板引擎的核心作用是将数据与模板结合,生成最终的 HTML 内容。在 Jav…

    2025年12月21日
    000
  • JavaScript数组扁平化_javascript数据转换

    JavaScript数组扁平化是将多维数组转为一维数组的过程,常用方法包括:使用ES2019的flat()方法可指定层级或Infinity展开全部;递归遍历数组并合并元素实现自定义逻辑;结合reduce与concat进行函数式编程处理;利用扩展运算符与some循环展开直至无嵌套。推荐优先使用flat…

    2025年12月21日
    000
  • JavaScript状态管理方案_javascript应用架构

    答案:现代前端状态管理方案包括React内置的useState和useReducer,适合局部UI状态;Redux及Redux Toolkit适用于中大型项目,提供可预测的状态管理;Zustand以极简API和自动订阅优势适合中小型项目;MobX通过响应式机制实现高效更新,适合高频状态变化场景;Co…

    2025年12月21日
    000
  • JavaScript中如何操作日期_Date对象常见方法

    JavaScript Date对象是处理时间的核心,需注意本地/UTC方法区别、月份从0开始、字符串解析兼容性及时间戳计算优先等关键细节。 JavaScript 中的 Date 对象是处理时间的核心工具,掌握它的常用方法能快速完成日期获取、格式化、计算和比较等任务。关键在于理解哪些方法返回本地时间、…

    好文分享 2025年12月21日
    000
  • JavaScriptProxy应用场景_JavaScript高级特性实战

    Proxy可拦截对象操作,实现响应式系统与表单验证:1. 通过get/set监听数据读取与修改,自动触发视图更新;2. 在set中校验值合法性,即时反馈错误。 JavaScript中的Proxy是一种强大的高级特性,允许你拦截并自定义对象的基本操作,比如读取、赋值、枚举等。它在实际开发中有着广泛的应…

    2025年12月21日
    000
  • JavaScript中什么是事件委托_它有什么优点

    事件委托是利用事件冒泡将监听器绑定在父元素上以统一处理子元素事件的技术;它节省内存、支持动态内容、简化维护并提升性能,但仅适用于冒泡事件,且需注意目标元素层级问题。 事件委托是一种利用事件冒泡机制,将事件监听器绑定在父元素上,而不是直接绑定在每个子元素上的技术。它让父元素统一处理子元素的事件,即使子…

    2025年12月21日
    000
  • JavaScript对象属性描述_JavaScript元编程技巧

    JavaScript对象属性通过描述符实现精细控制,分为数据描述符和访问器描述符,分别包含value/writable或get/set等元信息,不可混用;利用Object.defineProperty或Reflect.defineProperty可设置writable、enumerable、conf…

    2025年12月21日
    000
  • 前端安全防护措施_预防XSS与CSRF攻击的方法

    防范XSS需转义用户输入、避免innerHTML、启用CSP、过滤动态代码;防御CSRF应使用SameSite Cookie、配合Token验证、禁用GET敏感操作;通用措施包括最小权限、更新依赖、增加确认提示,协同前后端提升安全性。 在前端开发中,安全是不可忽视的一环。XSS(跨站脚本攻击)和CS…

    2025年12月21日
    000
  • JavaScript中什么是Ajax_如何发起请求

    Ajax是一种不刷新页面即可与服务器交换数据并更新部分网页内容的开发模式,核心是XMLHttpRequest对象;现代常用fetch API(基于Promise),中大型项目多用axios库封装处理。 Ajax(Asynchronous JavaScript and XML)不是某一个技术,而是一种…

    2025年12月21日
    000
  • javascript_模块加载器原理

    模块加载器核心是动态管理依赖并隔离作用域,采用IIFE封装模块,通过define和require声明依赖,按拓扑顺序异步加载,利用状态机与缓存机制控制执行,相比ES Modules更灵活但缺乏静态优化,适用于老项目或动态加载场景。 JavaScript模块加载器的核心作用是动态管理代码的依赖关系,让…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信