es6基础:类、继承、重写
es6
真正的引入的面相对象的类
,以前我们总是通过其他手段来模拟类
这种形式,现在终于有了,我有点开心,又有点难过,因为在我看来,js
并不是所谓的面相对象的语言,反而更偏向函数式,原型继承是他真正的面目。面相对象不过是人们在思考问题时总结出一套有效的、大家都认同的解决问题的思路。在其他语言、各种领域取得成功之后,又将这种思想带入js
中,为的是将已有的经验可以复用到js
,从而更有效的解决js
中的问题。
的确,面相对象是一个很有用的思考模块,在分解真实世界、大型项目的维护上有很大的好处,但是却缺少了函数式的灵巧。曾经想用完全面向对象的方式写一个redux
,却发现无法用这种方式写出compose
这种神奇的东西。
或许是我还没能在面相对象和函数式之间取得一种平衡,以取得面相对象和函数式共同的优点。
0x001 类
普通的类
普通的类
class Person{}
类表达式
// 匿名类 let Person=class{} // 具名类 let Person=class Person{}
0x001 初始化类和构造函数
实例化类
可以使用new
来调用一个类,从而实例化一个类实例
class Person{}
new Person() // Person{}构造函数
使用new
实例化一个类实例之后,将会自动调用该类的构造函数constructor
,并且可以传递参数class Person{
constructor(name, age){
console.log(name, age)
}
}
new Person("jack", 23) // 'jack', 23类变量
类中可以保存一些变量,在类中,可以通过this.variable_name
来访问,在类外,可以通过instance_name.variable_name
只有类实例可以访问他们,并且每个类实例的变量都是属于每个类实例的。class Person {
constructor(nickname, age){
this.nickname = nickname
this.age = age
}
}
console.log(Person.nickname) // undefined
console.log(Person.age) // undefined let person=new Person("jack",23)
console.log(person.nickname) // 'jack'
console.log(person.age) // let person2=new Person("maria",11)
console.log(person2.nickname) // 'maria'
console.log(person2.age) //类方法
类方法是定义在类内部的函数,可以在类内部调用:this.function_name(params)
,也可以在实例上调用:instance_name.function_name(params)
class Person{
constructor(nickname, age){
this.nickname = nickname
this.age =age
}
getNickname(){
return this.nickname
}
getAge(){
return this.age
}
summary(){
return `${this.nickname}:${this.age}`
}
}
let person=new Person('jack', 23)
console.log(person.getNickname()) // ''jack
console.log(person.getAge()) //
console.log(person.summary()) // 'jack:23'静态方法
静态方法是可以通过类直接调用的方法,不需要实例化class Person{
static sayHello(){
console.log('hello')
}
}
Person.sayHello() // 'hello'继承
继承就是将父类所有的方法和都继承下来,包括构造函数
class Person{
constructor(nickname, age){
this.nickname = nickname
this.age =age
}
getNickname(){
return this.nickname
}
getAge(){
return this.age
}
summary(){
return 'this is Person'
}
}
class Male extends Person {}
let male=new Male('jack',23)
console.log(male.nickname) // 'jack'
console.log(male.age) //
console.log(male.getNickname()) // 'jack'
console.log(male.getAge()) //
console.log(male.summary()) // 'this is Person'class Far {
constructor(x, y) {
this.x = x;
this.y = y;
}
sum() {
console.log(this.x + this.y);
}
} class Jc extends Far {
constructor(x, y) {
super(x, y);
}
} new Jc(1, 2).sum();0x003 重写
有时候我们不希望一个函数的作用和父类一致,比如在上面的栗子中,
male.summary()
返回this is Person
,不符合我们的逾期,我们希望返回this is Male
,这个时候就可以用到重写,只要写一个和父类相同名字和函数就行了,甚至参数个数不一致也不影响class Person{
constructor(nickname, age){
this.nickname = nickname
this.age =age
}
getNickname(){
return this.nickname
}
getAge(){
return this.age
}
summary(){
return 'this is Person'
}
}
class Male extends Person {
summary(){
return 'this is Male'
}
}
let male=new Male()
console.log(male.summary()) // this is Male
es6基础:类、继承、重写的更多相关文章
- C++基础——类继承中方法重载
一.前言 在上一篇C++基础博文中讨论了C++最基本的代码重用特性——类继承,派生类可以在继承基类元素的同时,添加新的成员和方法.但是没有考虑一种情况:派生类继承下来的方法的实现细节并不一定适合派生类 ...
- ES6——class类继承(读书笔记)
前言 我一定是一个傻子,昨天这篇文章其实我已经写好了一半了,但是我没有保存 这是学习ES6的过程,我没有系统的看完阮大大的书.零零散散的,很多功能知道,但是没有实际的用过 看了几遍,总是看前面几章,所 ...
- C++基础——类继承
一.前言 好吧,本系列博客已经变成了<C++ Primer Plus>的读书笔记,尴尬.在使用C语言时,多通过添加库函数的方式实现代码重用,但有一个弊端就是原来写好的代码并不完全适用于现 ...
- java基础 类 & 继承
类 在Java中,类文件是以.java为后缀的代码文件,在每个类文件中可以有多个类,但是最多只允许出现一个public类,当有public类的时候,类文件的名称必须和public类的名称相同,若不存在 ...
- 深入解析ES6 更易于继承的类语法的使用
和其它面向对象编程语言一样,ES6 正式定义了 class 类以及 extend 继承语法糖,并且支持静态.派生.抽象.迭代.单例等,而且根据 ES6 的新特性衍生出很多有趣的用法. 一.类的基本定义 ...
- 实现Square类,让其继承自Rectangle类,并在Square类增添新属性和方法,在2的基础上,在Square类中重写Rectangle类中的初始化和打印方法
实现Square类,让其继承自Rectangle类,并在Square类增添新属性和方法,在2的基础上,在Square类中重写Rectangle类中的初始化和打印方法 #import <Found ...
- Python基础(十一) 类继承
类继承: 继承的想法在于,充份利用已有类的功能,在其基础上来扩展来定义新的类. Parent Class(父类) 与 Child Class(子类): 被继承的类称为父类,继承的类称为子类,一个父类, ...
- C#基础--类/接口/成员修饰符,多态、重载、重写,静态和非静态
C#基础--类/接口/成员修饰符,多态.重载.重写,静态和非静态 类/接口/成员修饰符 C#修饰符---接口: 接口默认访问符是internal接口的成员默认访问修饰符是public C#修饰符--类 ...
- ES6中的类继承和ES5中的继承模式详解
1.ES5中的继承模式 我们先看ES5中的继承. 既然要实现继承,首先我们得要有一个父类. Animal.prototype.eat = function(food) { console.log(th ...
- 创建线程的一般方式和匿名内部类方式对比——继承thread类,重写run()方法
第一种:继承thread类,重写run()方法 一般方式:Demo01.java /** * 创建线程的第一种方式:继承thread类,重写run()方法 * * @author :liuqi * @ ...
随机推荐
- 老男孩Linux运维50期 --于海科--决心书
1.我叫于海科,来自于甘肃省天水市,之前就读于兰州石化职业技术学院,我是听之前的学长说老男孩教育出来就业不错,我特此来这培训希望出来能够找到一份不错的工作.2.五个月学完,目标薪资是11k.3.达到目 ...
- TOP-K Problems
最小的K个数 直接数组排序,取出前K个.复杂度\(O(nlogn)\). 分治 此题只要求出最小的K个数,并不要求这K个数有序. 我们可以借鉴快排中的partition做法,将比第K个数小的都放前面, ...
- Codeforces Round #530 (Div. 1) 1098A Sum in the tree
A. Sum in the tree Mitya has a rooted tree with nn vertices indexed from 11 to nn, where the root ha ...
- 如何使用简单 PHP 对象 POPO (Plain old PHP Object) 来优化你的代码
如果您熟悉 Java,可能您已经知道 POJO (普通 Java 类). 因为 POJO 这个词最早是由 Martin Fowler.Rebecca Parsons 和 Josh MacKenzie ...
- Java——多线程之Lock锁
Java多线系列文章是Java多线程的详解介绍,对多线程还不熟悉的同学可以先去看一下我的这篇博客Java基础系列3:多线程超详细总结,这篇博客从宏观层面介绍了多线程的整体概况,接下来的几篇文章是对多线 ...
- Jetson AGX Xavier/Ubuntu更改pip3源
pip3换源: 修改~/.pip/pip.conf,如果没有这个文件,就创建一个. 内容如下: [global]index-url = https://pypi.tuna.tsinghua.edu.c ...
- 猫狗大战("简单的二维背包")
题面:https://www.luogu.com.cn/problem/P1489 看上去是一道简单的二维费用背包,但是要特别小心循环顺序. Ⅰ先循环物品,再循环限制条件. Ⅱ每一个限制条件都必须从后 ...
- Spring mvc的基本配置及工作原理
1.spring mvc框架搭建 需求:在浏览器输入一个请求login.do,跳转到登录成功界面. 第一步,创建web项目,导入jar包 注意: 第二步,在web.xml中配置spring的核心监听器 ...
- oracle如何实现去重和分页
一:oracle实现去重: user数据表: 分两步:1.查询重复数据 2.删除重复数据 1.查询重复数据:在oracle中实现查询重复数据,可以借助于rowid这个伪列.oracle中每个表物理上 ...
- 自动化运维工具Ansible之Roles测验详解
Ansible Roles 详解与实战案例 主机规划 添加用户账号 说明: 1. 运维人员使用的登录账号: 2. 所有的业务都放在 /app/ 下「yun用户的家目录」,避免业务数据乱放: 3. 该用 ...