Js——面向对象

基本概念

类:类型、模板、统称(狗类、猫类)

对象:是类的一个类别,会具体到某一事物上(天上飞的那只鸟,家里的那只猫)

继承:狗类继承至哺乳动物类,猫类也继承到哺乳动物类,继承后,子类可以使用父类的属性和方法

新语法与旧语法

ES5面向对象语法(prototype)

构造函数:用于创建对象的函数

原型对象:prototype

​    // es5没有类的概念,通过构造函数来实现类
    // 构造函数的函数名,首字母大写
    // 构造函数是用来创建对象用的
    function Cat (name, age) {
      this.name = name
      this.age = age
    }

    // 通过原型对象,为构造函数生成的对象赋予新的方法
    Cat.prototype.sayName = function () {
      console.log(`我的名字是${this.name}`)
    }

    var cat = new Cat("猫猫", 3)   //创建了一个对象,猫类的实例
    var bigCat = new Cat("小猫", 2)
    cat.sayName()
    bigCat.sayName()
​

原型链:实现继承(了解)

    function Aniaml (name) {
      this.name = name
    }

    Aniaml.prototype.sayName = function () {
      console.log(`你好,我是${this.name}`)
    }

    Aniaml.prototype.sayHello = function () {
      console.log("hello!!!")
    }

    function Dog (name) {
      this.name = name
    }

    Dog.prototype = new Aniaml()

    var a = new Aniaml("小羊")
    a.sayName()

    var dog = new Dog("小黑")
    dog.sayName()
    dog.sayHello()
    // 子类构造函数可以调用父类构造函数的所有属性和方法

ES6(2015)面向对象语法

Class关键字

    // ES2015(ES6)
    class Dog {
      constructor(name, age) {
        this.name = name
        this.age = age
      }
      sayName () {
        console.log(`我是${this.name}`)
      }
    }
    let dog = new Dog("小黑", 2)
    dog.sayName()

继承

   class Animal {
      constructor(name) {
        this.name = name
      }
      sayName () {
        console.log(`我是${this.name}`)
      }
    }
    class Dog extends Animal {
      constructor(name, age) {
        super(name)
        this.age = age
      }
    }
    let dog = new Dog("小黑", 2)
    console.log(dog.age);

总结:前端开发过程中,大部分情况我们不需要通过定义类来完成开发任务,但是很多时候我们会使用别人定义的类(例如第三方库框架

练习:

1. 扩展Date对象实现如下功能,实现dateFormate方法,返回值是"xxxx年xx月xx日"

2. 定义一个Person类,让Student类和Teacher类继承Person,为Person类添加getInformation方法,使Student类和Teacher类都可以通过此方法获取个人信息

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值