class类

ES6提供了更接近传统语言的写法,引入了Class这个概念,作为对象的模板。通过class关键字,可以定义类。

基本上,ES6的class可以看作只是一个语法糖,它的绝大部分功能,ES5都可以做到,新的class写法只是让对象原型的写法更加清晰、更像面向对象编程的语法而已。

构造函数

在ES5中,我们也可以实现构造函数:

 

 在ES6中,我们实现使用class来实现相同的功能:

 需要注意的是,在class里面,方法必须使用call(){}的这个语法形式,不能使用ES5中对象的完整形式。

 继承

在ES5中使用prototype实现继承

 function Phone(brand,price){
            this.price = price;
            this.brand = brand;
        }
        Phone.prototype.call = function(){
            console.log('我可以打电话');
        }
        function SmartPhone(brand,price,color,size){
            Phone.call(this,brand,price);
            this.color = color;
            this.size = size;
        }
        //设置子级构造函数的原型
        SmartPhone.prototype = new Phone;
        SmartPhone.prototype.constructor = SmartPhone;

        //声明子类的方法
        SmartPhone.prototype.Phone = function(){
            console.log('我可以拍照');
        }
        SmartPhone.prototype.playGame = function(){
            console.log('我可以玩游戏');
        }
        const Huawei = new SmartPhone('华为',4999,'黑色','5.5');
        Huawei.call();
        Huawei.playGame();
        console.log(Huawei);

 在ES6中实现继承就要简便很多

class Phone{
            constructor(brand,price){
                this.price = price;
                this.brand = brand;
            }
            call(){
                console.log('我可以打电话');
            }
        }
        class SmartPhone extends Phone{
            constructor(brand,price,color,size){
               super(brand,price);
                this.color = color;
                this.size = size;
            }
            Phone(){
                console.log('我可以拍照');
            }
            playGame(){
                console.log('我可以玩游戏');
            }

        }
        const Huawei = new SmartPhone('华为',4999,'黑色','5.5');
        Huawei.call();
        Huawei.playGame();
        console.log(Huawei);

 class中的getter和setter方法

 

 

posted on 2020-12-08 13:30  紅葉  阅读(161)  评论(0编辑  收藏  举报