JavaScript面向对象

JavaScript面向对象:

面向过程

面向过程就是讲需求一步一步自己完全实现
如:一堆衣服,需要自己一件一件洗。

面向对象

面向对象是把有共同特征的方法抽取为类
比如:一堆衣服,都需要洗,创建洗衣机类 女朋友类,让她洗。

类的定义和使用:

定义格式:

    class 类名 {
        //构造方法
        constructor(变量列表) {
     		变量赋值
        }

        方法名(参数列表) {
        	方法体;
        	return;
        }

第一种:class类{}

使用:let 对象名 = new 类名();

<script>
    //定义Person类
    class Person {
        //构造方法
        constructor(name, age) {
            this.name = name;
            this.age = age;
        }

        //show方法
        show() {
            document.write(this.name + "," + this.age + "<br>");
        }

        //eat方法
        eat() {
            document.write("吃饭...");
        }
    }

    //使用Person类
    let p = new Person("张三", 23);
    p.show();
    p.eat();
</script>

第二种:字面量定义

使用:对象名.方法

<script>
    // 定义类
    let person = {
        name: "itzhuzhu",
        age: 23,
        // 定义数组
        hobby: ["看美女", "想美女", "玩美女"],

        eat: function () {
            document.write("看美女吃饭");
        }
    };
    // 使用类和方法
    document.write(person.name + "," + person.age + "," + person.hobby[0] + "," + person.hobby.length);
    person.eat();
</script
继承:

让类与类产生子父类的关系,子类可以使用父类有权限的成员。
继承关键字:extends
顶级父类:Object

<script>
    //定义Person类
    class Person{
        //构造方法
        constructor(name,age){
            this.name = name;
            this.age = age;
        }

        //eat方法
        eat(){
            document.write("吃饭...");
        }
    }

    //定义Worker类继承Person
    class Worker extends Person{
        constructor(name,age,salary){
            super(name,age);
            this.salary = salary;
        }

        show(){
            document.write(this.name + "," + this.age + "," + this.salary + "<br>");
        }
    }

    //使用Worker
    let w = new Worker("张三",23,10000);
    w.show();
    w.eat();
</script
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

itzhuzhu.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值