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
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值