ES5构造函数实现继承和ES6中class的类继承

1.ES5构造函数实现继承

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>对象继承</title>
</head>
<body>
    <script>
        //手机
        function Phone(brand,price){
            this.brand=brand;
            this.price=price;
        }

        Phone.prototype.call = function(){
            console.log("我可以打电话");
        }
        //继承
        function SmartPhone(brand,prise,color,size){
            Phone.call(this,brand,prise);
            this.color=color;
            this.size=size;
        }
        //设置子集构建函数原型
        SmartPhone.prototype = new Phone;
        SmartPhone.prototype.constructor=SmartPhone;

        //声明子类方法
        SmartPhone.prototype.photo=function(){
            console.log("我可以拍照");
        }

        SmartPhone.prototype.playGame=function(){
            console.log("我可以玩游戏");
        }

        const chuizi = new SmartPhone('锤子',1999,'黑色','5.5inch');
        console.log(chuizi);


    </script>
</body>
</html>

2.ES6中class的类继承

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>类继承</title>
</head>
<body>
    <script>
        class Phone{
            //构造方法
            constructor(brand,price){
                this.brand=brand;
                this.price=price;
            }
            //父类的成员属性
            call(){
                console.log("我可以打电话");
            }
        }

        class SmartPhone extends Phone{
            //构造方法
            constructor(brand,price,color,size){
                super(brand,price);
                this.color=color;
                this.size=size;
            }
            //子类中独有的方法
            photo(){
                console.log("拍照");
            }
            playGame(){
                console.log("玩游戏");
            }
        }

        const xiaomi =new SmartPhone('小米',8888,'黑色','55inch');
        console.log(xiaomi);
    </script>
    
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值