2018-07-16 JS中ES6 面向对象 与 ES5 面向对象的差别

JS中ES6对象与ES5对象的差别

ES6对象与ES5对象的差别

2018 7/16
晴-小雨 微风 温度 12-24°C

在es6中的面相对象与es5中的面向对象的区别是极大的,es6中的面相对象则更像原汁原味的后端语言像java,c++等,而且在es5中的class保留字,在es6中也成了实际有效的关键字。

我们来做个对比,

es5中创建一个对象需要用函数的形式去仿造后段语言中对象的形式去造对象:

function ren(name,age){

this.name=name;

this.age=age;

}

ren.prototype.aet = function(foot){

console.log(this.name+"aet"+foot);

}

var xiaoming = new ren("xiaoming",24);

xiaoming.aet("面包");

/这是es5中 主流创建对象的方法之一,方法写在原型链中/

而es6中造对象则更为直观与简便,

class ren{

//先创建构造函数

constructor(name,sex,age,id){

    this.name=name;

    this.sex=sex;

    this.age=age;

    this.id=id;

}

//ES6中的对象的方法不需要单独写在原型链中

 say(){

    console.log(this.name+"说话");

}

//ES6中多了静态方法的声明与使用,静态方法是实例对象无法调用的,是通过原型.方法名进行调用,

 静态方法 多数用于存储 公共方法,比如说要给 这一批 同类对象 进行排序等

static paixu(){

    console.log(this);

}

}

let ren1=new ren("小王","男",18,"10010");

//输出一下该对象

console.log(run1);

//调用ren1对象的say方法

ren1.say();

//调用原型中的排序方法,该方法在此处并没有实际作用

ren.paixu();

//ES6中的对象继承,与ES5不同,ES6中的继承 是与后端语言十分相像,

// 但是这里的继承 格式 是 class + 子类名 + extends + 基类 {};

class student extends ren{

//这里需要注意 构造函数的继承 需要 这样写

// constructor (参数){

super(基类参数);

***************

}

constructor(name,sex,age,id,sid){

super(name,sex,age,id);

this.sid=sid;

}

kaoshi(){

console.log(this.name+"考试");

}

let student1 = new student();

student1.name="xiaoming";

student.say();

console.log(studnet1);

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在es6中的面相对象与es5中的面向对象的区别是极大的,ea6中的面相对象则更像原汁原味的后端语言像java,c+...
    追key阅读 768评论 0 7
  • JavaScript 快速入门 面向对象编程创建对象构造函数忘记写new怎么办?原型继承class继承 面向对象编...
    染微言阅读 270评论 0 0
  • avaScript对每个创建的对象都会设置一个原型,指向它的原型对象。 当我们用obj.xxx访问一个对象的属性时...
    源大侠阅读 271评论 0 1
  • 年轻人——只需睡前10步,减压抗疲劳,保持好身材 减肥方法有很多,运动减肥毫无疑问是首选。可是对于懒妹子和汉子们们...
    墨茶的明天阅读 454评论 0 4
  • 古人说,不读诗词,不足以知春秋历史;不读诗词,不足以品文化精萃;不读诗词,不足以感天地草木之灵;不读诗词,不足以见...
    慕一雪阅读 278评论 0 0