JavaScript 中 ES6

devtools/2024/11/15 0:34:22/

在ES6(ECMAScript 2015)中,JavaScript引入了一些新的语法和特性来支持面向对象编程(OOP)。下面是对ES6中面向对象编程的详细解释:

  1. 类(Class): ES6引入了类的概念,使得面向对象编程更加直观和易用。类是对象的蓝图,用于定义对象的属性和方法。

    javascript">class Person {constructor(name) {this.name = name;}sayHello() {console.log(`Hello, my name is ${this.name}.`);}
    }let person = new Person("John");
    person.sayHello();  // 输出:Hello, my name is John.
    
  2. 构造函数(Constructor): 类中的构造函数通过 constructor 关键字定义。它在创建类的实例时被调用,并用于初始化对象的状态。

    javascript">class Person {constructor(name) {this.name = name;}
    }let person = new Person("John");
    console.log(person.name);  // 输出:John
    
  3. 继承(Inheritance): ES6引入了 extends 关键字,使得类可以继承另一个类的属性和方法。子类可以通过继承获得父类的特性,并且可以扩展或重写它们。

    javascript">class Animal {constructor(name) {this.name = name;}speak() {console.log(`${this.name} makes a sound.`);}
    }class Dog extends Animal {speak() {console.log(`${this.name} barks.`);}
    }let dog = new Dog("Buddy");
    dog.speak();  // 输出:Buddy barks.
    
  4. 静态方法(Static Methods): 静态方法属于类本身,而不是类的实例。它们可以通过类名直接调用,无需创建对象实例。

    javascript">class MathUtils {static add(a, b) {return a + b;}
    }console.log(MathUtils.add(2, 3));  // 输出:5
    
  5. Getter 和 Setter: ES6引入了 getset 关键字,用于定义访问对象属性的特殊方法。get 用于获取属性值,set 用于设置属性值。

    javascript">class Circle {constructor(radius) {this.radius = radius;}get diameter() {return this.radius * 2;}set diameter(diameter) {this.radius = diameter / 2;}
    }let circle = new Circle(5);
    console.log(circle.diameter);  // 输出:10
    circle.diameter = 14;
    console.log(circle.radius);  // 输出:7
    
  6. 箭头函数(Arrow Functions): 箭头函数是ES6中的一种新的函数语法,它具有更简洁的语法形式和词法作用域绑定。箭头函数通常用于定义类方法和回调函数。

    javascript">class Timer {constructor() {this.seconds = 0;}start() {setInterval(() => {this.seconds++;console.log(`Timer: ${this.seconds} seconds.`);}, 1000);}
    }let timer = new Timer();
    timer.start();  // 每秒输出计时器的秒数
    

ES6的面向对象编程引入了类、构造函数、继承、静态方法、Getter和Setter等特性,使得JavaScript更加适合大型应用程序和复杂的代码组织。这些新的语法和特性提供了更清晰、更模块化的代码结构,使得面向对象编程更加直观和易于理解。


http://www.ppmy.cn/devtools/26792.html

相关文章

webox微信群发器多少钱?电脑微信群发软件哪个好用?微信群发助手一次能发多少人?最强稳定群发器来袭

今天给大家推荐一款我们目前在使用的电脑群发工具WeBox,不仅可以无限多开,方便你同时管理多个账号,群发功能更是十分强大,轻松释放你的双手。 软件下载地址>>密码:4as1 WeBox群发功能 下载WeBox打开登录&#x…

李沐69_BERT训练集——自学笔记

NLP里的迁移学习 1.使用预训练好的模型来抽取词、句子的特征,例如word2vec或语言模型 2.不更新预训练好的模型 3.需要构建新的网络来抓取新任务需要的信息:word2vec忽略了时序信息,语言模型只看了一个方向 BERT的动机 1.基于微调的NLP模…

C#调用skiasharp实现绘制并拖拽图形

SkiaSharp是基于.net的跨平台二维图形库,封装的谷歌的Skia库,SkiaSharp支持在以下平台或运行时中使用,能够在图片中绘图,也提供控件在Winform、WPF等使用。本文学习skiasharp在Winform的基本用法,并参照参考文献5实现绘…

【数据结构】图的应用(最小生成树、拓扑排序、最短路径等)

文章目录 最小生成树概念Prim算法基于邻接表的Prim算法:基于邻接矩阵的Prim算法 Kruskal算法基于邻接表的Kruskal算法:基于邻接矩阵的Kruskal算法: 有向无环图及其应用拓扑排序概念基于邻接表的拓扑排序算法:基于邻接矩阵的拓扑排…

ubuntu系统搭建pytorch环境详细步骤【笔记】

实践设备:华硕FX-PRO(NVIDIA GeForce GTX 960M) 搭建PyTorch环境的详细步骤如下: 1.安装Ubuntu系统: 下载Ubuntu的镜像文件并制作启动盘。将启动盘插入计算机,启动计算机并按照提示安装Ubuntu系统。 2.…

mac 初始环境搭建

首先是jdk 我用的是1.8版本 去oracle官网。直接安装。1.8 的jdk。 这是链接。 一、准备安装包 苹果的mac book目前常见的有两种芯片的 一种是intel芯片的,一种是Apple Silicon的。为了更好的体现不同芯片的性能,各种开发工具包给出了不同的实现&am…

【介绍下Unity编辑器扩展】

🌈个人主页: 程序员不想敲代码啊 🏆CSDN优质创作者,CSDN实力新星,CSDN博客专家 👍点赞⭐评论⭐收藏 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共…

十一、大模型-Semantic Kernel与 LangChain 的对比

Semantic Kernel 与 LangChain 的对比 Semantic Kernel 和 LangChain 都是用于开发基于大型语言模型(LLM)的应用程序的框架,但它们各有特点和优势。 基本概念和目标 Semantic Kernel 是一个由微软开发的轻量级 SDK,旨在帮助开发…