ES6新增语法(四)——面向对象

系统运
• 阅读 1232

ES6中json的2个变化

简写:名字和值相同时,json可以可以简写

let a=12,b=5;
let json = {
 a,
 b
}
console.log(json) // { a:12 , b:5 }

省略function:json中的函数可以简写

let persen ={
 name:'倩倩',
 age:18,
 showName(){
  alert(this.name)
 }
}
persen.showName()

ES6与传统面向对象

传统面向对象:类和构造函数在一起,为对象添加方法时使用prototype。传统面向对象实例如下:

function Person(name,age){
 this.name = name;
 this.age = age
}
Person.prototype.showName = function(){
 console.log('我叫',this.name)
}
Person.prototype.showAge = function(){
 console.log('今年',this.age,'岁')
}
var p = new Person('倩倩',18)
p.showName()
p.showAge()

ES6面向对象:将类和构造函数分开。

类:class

构造函数:constructor指生成完实例之后,自己就执行的函数。

class Person{
 constructor(name,age){
  this.name = name;
  this.age = age;
 }
  //给对象添加方法
 showName(){
  console.log('我叫',this.name)
 }
 showAge(){
  console.log('今年',this.age,"岁")
 }
}
var p =new Person('倩倩',18);
p.showName();
p.showAge()

面向对象的继承

传统面向对象的继承:

  • 使用apply方法,子类继承父类全部属性。
  • 使用prototype方法,子类继承父类的方法。

传统面向对象的继承实例如下:

function Person(name,age){
 this.name = name;
 this.age = age
}
Person.prototype.showName = function(){
 console.log('我叫',this.name)
}
Person.prototype.showAge = function(){
 console.log('今年',this.age,'岁')
}
function Worker(name,age,job){
 Person.apply(this,arguments)//继承属性
 this.job = job
}
Worker.prototype = new Person();//继承方法
Worker.prototype.showJob = function(){
 console.log('工作是',this.job);
}
var w = new Worker('倩倩',18,'打杂');
w.showName();
w.showAge();
w.showJob();

ES6面向对象继承:

使用extends实现子类对父级的继承,super()将父类的属性继承过来。

class Person{
 constructor(name,age){
  this.name = name;
  this.age = age;
}
 showName(){
  console.log('我叫',this.name)
 }
 showAge(){
  console.log('今年',this.age,"岁")
 }
}
class Worker extends Person {
 constructor(name,age,job){
   super(name,age)
   this.job = job
 }
 showJob(){
  console.log('工作是',this.job)
 }
}
var w = new Worker('倩倩',18,'打杂');
w.showName();
w.showAge();
w.showJob()

关于super:

子类中有constructor,内部就要有super,因为子类没有自己的this对象,需要继承父类的this对象。

这里的super(name,age)就是调用父类的构造函数。

super 虽然代表了Person的构造函数,但是返回的是子类Worker的实例。

ES6面向对象优点

ES6面向对象相比传统面向对象,语法简化
ES6语法标准、统一,适合大项目开发,不易产生冲突。
ES6是系统提供的标准语法,可以忽略兼容性问题。

点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Wesley13 Wesley13
4年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Easter79 Easter79
4年前
typeScript数据类型
//布尔类型letisDone:booleanfalse;//数字类型所有数字都是浮点数numberletdecLiteral:number6;lethexLiteral:number0xf00d;letbinaryLiteral:number0b101
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
4年前
List的Select 和Select().tolist()
List<PersondelpnewList<Person{newPerson{Id1,Name"小明1",Age11,Sign0},newPerson{Id2,Name"小明2",Age12,
Wesley13 Wesley13
4年前
FLV文件格式
1.        FLV文件对齐方式FLV文件以大端对齐方式存放多字节整型。如存放数字无符号16位的数字300(0x012C),那么在FLV文件中存放的顺序是:|0x01|0x2C|。如果是无符号32位数字300(0x0000012C),那么在FLV文件中的存放顺序是:|0x00|0x00|0x00|0x01|0x2C。2.  
Wesley13 Wesley13
4年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
4年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Wesley13 Wesley13
4年前
MBR笔记
<bochs:100000000000e\WGUI\Simclientsize(0,0)!stretchedsize(640,480)!<bochs:2b0x7c00<bochs:3c00000003740i\BIOS\$Revision:1.166$$Date:2006/08/1117
系统运
系统运
Lv1
若为化得身千亿,散上峰头望故乡。
文章
5
粉丝
0
获赞
0