用es6的class关键字定义一个类
es6新增class关键字使用方法详解。
通过class关键字,可以定义类。基本上,ES6的class可以看作只是一个语法糖,它的绝大部分功能,ES5都可以做到,新的class写法只是让对象原型的写法更加清晰、更像面向对象编程的语法而已。
实例讲解:
es5的定义类方法:
function extend(obj1,obj2){//合并对象属性的方法
for(var attr in obj2){
obj1[attr]=obj2[attr];
}
};
function Person(opt){
this.settings = {
'name':'jack',
'age':'30',
'sex':'male',
'eye':'Single eyelid',//Double-fold eyelids
'Height':'tall',//or Medium
'Weight':'fat', //or thin
}
extend(this.settings,opt);
};
Person.prototype.message=function(){
console.log(this.settings.name+"今年"+this.settings.age+'岁。'+'性别:'+this.settings.sex+"。特点:"+this.settings.eye+","+this.settings.Height+","+this.settings.Weight);
};
var p1=new Person({});
p1.message();
console.log(p1);
var p2 = new Person({
'name':'lily',
'age':'23',
'sex':'femal',
'eye':'Double-fold eyelids',//Double-fold eyelids
'Height':'Medium',//or Medium
'Weight':'Medium', //or thin
});
p2.message();
console.log(p1.__proto__ === p2.__proto__)//true;
es6的定义类方法:
class Person{
constructor(opt) {
this.settings={
'name':'jack',
'age':'30',
'sex':'male',
'eye':'Single eyelid',//Double-fold eyelids
'Height':'tall',//or Medium
'Weight':'fat', //or thin
};
extend(this.settings,opt);
}
message(){
console.log(this.settings.name+"今年"+this.settings.age+'岁。'+'性别:'+this.settings.sex+"。特点:"+this.settings.eye+","+this.settings.Height+","+this.settings.Weight);
}
}
var p1=new Person({});
p1.message();
console.log(p1);
var p2 = new Person({
'name':'lily',
'age':'23',
'sex':'femal',
'eye':'Double-fold eyelids',//Double-fold eyelids
'Height':'Medium',//or Medium
'Weight':'Medium', //or thin
});
p2.message();
console.log(p1.__proto__ === p2.__proto__)//true;
//两个原型链是一样的说明是指向的同一个内存。
如何实现类的继承?
es5实现类的继承方法:
//传统的继承的写法。 function Pchild(opt){
Person.call(this,opt);//属性通过call:this方式继承。
}
extend(Pchild.prototype,Person.prototype );//方法通过extend继承。 Pchild.prototype.languge=function(){
console.log(this.settings.name+'come from'+this.settings.country+'speak:'+this.settings.language);
}
var c1 = new Pchild({
'name':'licy',
'age':'23',
'sex':'femal',
'eye':'Double-fold eyelids',//Double-fold eyelids
'Height':'Medium',//or Medium
'Weight':'Medium', //or thin
'country':'canada',
'language':'English'
});
c1.message();
c1.languge()
console.log(c1);
es6实现继承的方法:使用extends关键字。
class Pchild extends Person{
languge(){
console.log(this.settings.name+'.come from:'+this.settings.country+'speak:'+this.settings.language+"后面是继承父级的方法");
super.message();
}
}
var c1 = new Pchild({
'name':'licy',
'age':'23',
'sex':'femal',
'eye':'Double-fold eyelids',//Double-fold eyelids
'Height':'Medium',//or Medium
'Weight':'Medium', //or thin
'country':'canada',
'language':'English'
});
c1.message();
c1.languge()
console.log(c1);
console.log(p2);
es6的继承使用extends关键字来继承父级,使用super来调用父级的方法。
用es6的class关键字定义一个类的更多相关文章
- 怎样用Javascript定义一个类
其实Javascript中没有类这个定义,但是有类这个概念.很多人都写过这样的代码,对,没错,就是如下代码,清晰的不能再清晰了,就是一个关键字 function,然后定义一个方法名,方法名后紧跟一对括 ...
- Java分享笔记:自定义枚举类 & 使用enum关键字定义枚举类
在JDK1.5之前没有enum关键字,如果想使用枚举类,程序员需要根据Java语言的规则自行设计.从JDK1.5开始,Java语言添加了enum关键字,可以通过该关键字方便地定义枚举类.这种枚举类有自 ...
- Java TreeSet集合排序 && 定义一个类实现Comparator接口,覆盖compare方法 && 按照字符串长度排序
package TreeSetTest; import java.util.Iterator; import java.util.TreeSet; import javax.management.Ru ...
- JAVA 类的定义(定义一个类,来模拟“学生”)
package Code413;/*定义一个类,来模拟“学生”属性 (是什么) 姓名 年龄行为(能做什么) 吃饭 睡觉 学习对应到Java的类当中 成员变量(属性) String nanme; //姓 ...
- Python3.x:定义一个类并且调用
Python3.x:定义一个类并且调用 1,定一个类Shrjj(其中有属性:name, jjzt,fbsjj,etf,lof,fjlof): class Shrjj(object): def __in ...
- 定义一个类:实现功能可以返回随机的10个数字,随机的10个字母, 随机的10个字母和数字的组合;字母和数字的范围可以指定,类似(1~100)(A~z)
#习题2:定义一个类:实现功能可以返回随机的10个数字,随机的10个字母, #随机的10个字母和数字的组合:字母和数字的范围可以指定 class RandomString(): #随机数选择的范围作为 ...
- 103-PHP定义一个类
<?php class ren{ //定义人类 } class mao{ //定义猫类 } new ren(); //实例化人类 new mao(); //实例化猫类 new mao(); // ...
- 定义一个类Point,代表一个点,public属性有x和y,方法有显示点坐标 show(),构造函数有两个参数分别给x,y赋值,在main方法中构造两个对象,再创建一方法(getMiddle)为取两个点构成线段的中点的坐标,参数为2个点对象,调用此方法后得到一个新的点,编写Application,显示该对象的坐标值。
这个题让我更加明白了类创建对象的实质 代码中用到:1.对象作形参;2.对象作返回值 以下用代码具体分析: class Point1{ public double x; public double y; ...
- 按要求编写一个Java应用程序: (1)定义一个类,描述一个矩形,包含有长、宽两种属性,和计算面积方法。 (2)编写一个类,继承自矩形类,同时该类描述长方体,具有长、宽、高属性, 和计算体积的方法。 (3)编写一个测试类,对以上两个类进行测试,创建一个长方体,定义其长、 宽、高,输出其底面积和体积。
package jvxing; public class Jvxing { //成员变量 private double width; private double chang; public doub ...
随机推荐
- bzoj 3529 数表
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3529 题目大意:令F(i)为i的约数和,多次询问对于1<=x<=n,1< ...
- 第二篇--Jmeter测试Java请求
前提:需要准备eclipse作为开发工具,安装jdk,准备完毕,接下来开工喽! 1.新建Java工程BMIrisJNIJarTest,新建lib目录,将Jmeter安装目录下lib/ext包下的Apa ...
- Java后台开发必备软件(windows环境下)
一.必备软件 1.Jdk,推荐下载最新版2.Ide,推荐 IntelliJ IDEA3.服务器,如 tomcat / jetty4.数据库终端界面,推荐 Navicat Premium(自行破解),5 ...
- 使用CefSharp 在C#用户控件中嵌入Chrome浏览器使用方法
CEF(Chromium Embedded Framework, 嵌入式Chromium框架)是C/C++开发的库 目前 Google Chrome(Google浏览器),Chromium浏览器,Op ...
- 堆排序Java实现
package practice; import edu.princeton.cs.algs4.StdRandom; public class TestMain { public static voi ...
- 融会贯通——最常用的“合成复用原则”技能点Get
复用一个类的时候,多使用对象的组合/聚合的关联关系,而不是继承. 之前提到的"依赖倒转原则",是以里氏代换原则为基础的实现开闭原则目标的手段,这一条路线涉及到的是类的继承(包括单继 ...
- C# 导出Excel的示例(转)
using System; using System.Collections.Generic; using System.Text; using System.Data; using System.W ...
- VB与C#语言部分不用的地方Part1
1. 数据类型: ① 日期型(Date) 表示日期和时间用两个“#”符号把日期和时间的值括起来,如:#08/20/2001#.#2001-08-20#. ② 变体型(Variant) ...
- React——组件
一.创建组件 在React中有两种创建组件的方式,分别是函数形式的组件和类形式的组件 //函数形式: function Welcome(props){ return <p>this is ...
- ★不容错过的PPT教程!
IT工程师必须学会的计算机基础应用之一--PPT! 28项大神级PPT制作技术,学会后让你变成PPT高手哦!更多实用教程,请关注@IT工程师 !