JS - 构造函数讲解

JS之构造函数讲解

1,构造函数概念

  1. 在es6之前,对象不是基于类创建的,而是用一种称为构造函数的特殊函数来定义对象和它们的特征。
  2. 当需要很多很多对象时,而这些对象又有相同的属性和方法。这时需要把它抽离出来,再大量的生成对象,这时候就需要构造函数。
  3. 通过 new 函数名 来实例化对象的函数叫构造函数。
  4. 构造函数的名称首字母需要大写(规范)。

2,定义构造函数


 	function Student(name, age) {
        this.name = name
        this.age = age
        this.study = function() {
          console.log(this.name + '在学习')
        }
      }
      // 实例化一个对象zs
      var zs = new Student('张三', 18)
      console.log(zs) // Student {name: "张三", age: 18, study: ƒ}
      
      // 调用对象中的方法
      zs.study()
     
      ===========================注意 =============================
      实例成员就是构造函数内部通过this添加的成员  name  age  study就是实例成员
      实例成员只能通过实例化的对象来访问
      

3,在构造函数中 new 关键字做了什么操作?

  1. 创建一个新对象
  2. 将构造函数的作用域赋值给新的对象(因此this指向了新对象)
  3. 给这个新对象添加属性和方法
  4. 返回新对象

4,构造函数和普通函数的区别,

  1. 调用方式不一样
    a. 普通函数的调用方式:直接调用 person()即可。注意:只要这个函数没有使用new操作符,那它始终是一个普通函数,和首字母大写没有关系。
    b.构造函数的调用方式:需要使用new关键字来调用 new Person();
  2. 返回值不一样
    a. 普通函数可以使用return进行返回;
    b.构造函数不需要return返回。因为构造函数会马上创建一个新对象,并将该新对象作为返回值返回。
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来详细讲解一下。 1. 构造函数继承 构造函数继承是一种通过调用父构造函数来继承父类属性和方法的方式。在子类中通过调用父类构造函数来实现继承,子类的实例会具有父类的属性和方法。具体实现方式如下: ```javascript function Parent(name) { this.name = name; } Parent.prototype.sayName = function() { console.log(this.name); } function Child(name, age) { Parent.call(this, name); this.age = age; } var child = new Child('Tom', 18); console.log(child.name); // Tom console.log(child.age); // 18 ``` 在上面的代码中,我们定义了一个父类 Parent 和一个子类 Child,Child 通过在构造函数中调用 Parent 来实现继承。这种方式的缺点是无法继承父类原型上的方法。 2. 混合继承 混合继承是一种通过同时使用构造函数继承和原型链继承来继承父类属性和方法的方式。在子类中既通过调用父类构造函数来继承父类属性,又通过将子类的原型指向父类的实例来继承父类原型上的方法。具体实现方式如下: ```javascript function Parent(name) { this.name = name; } Parent.prototype.sayName = function() { console.log(this.name); } function Child(name, age) { Parent.call(this, name); this.age = age; } Child.prototype = new Parent(); Child.prototype.constructor = Child; var child = new Child('Tom', 18); console.log(child.name); // Tom console.log(child.age); // 18 child.sayName(); // Tom ``` 在上面的代码中,我们定义了一个父类 Parent 和一个子类 Child,Child 通过同时使用构造函数继承和原型链继承来实现继承。这种方式的优点是既可以继承父类的属性,也可以继承父类原型上的方法。 3. ES6 继承 ES6 继承是一种通过使用 class 和 extends 关键字来继承父类属性和方法的方式。在子类中使用 extends 关键字继承父类,子类的实例会具有父类的属性和方法。具体实现方式如下: ```javascript class Parent { constructor(name) { this.name = name; } sayName() { console.log(this.name); } } class Child extends Parent { constructor(name, age) { super(name); this.age = age; } } var child = new Child('Tom', 18); console.log(child.name); // Tom console.log(child.age); // 18 child.sayName(); // Tom ``` 在上面的代码中,我们使用 class 和 extends 来定义父类 Parent 和子类 Child,Child 通过 extends 关键字继承 Parent 来实现继承。这种方式是 ES6 中推荐的继承方式,具有语法简洁、易于理解等优点。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值