ES5构造函数语法 和 ES6构造函数class

1.构造函数

首先,我们来了解一下,什么是构造函数?(我来自逆战班)
构造函数,是一种专门用于生成对象的函数,通过构造函数,生成的对象,称为实例化对象。构造函数分为两种,一种是JavaScript程序定义好的构造函数,称为内置构造函数, 一种是程序员自己定义的构造函数,称为自定义构造函数。接下来,我们来了解一下自定义构造函数

2.ES5构造函数语法

我们先来看下面的函数
在这里插入图片描述
图片中就是ES5构造函数语法的使用,通过构造函数NewObj(自定义构造函数名称要使用大驼峰命名法)生成实例化对象。在函数中,有一个属性叫做prototype,其中可以定义,存储,,属性属性值,函数名称函数等等数据。而在对象中,有一个属性叫 proto,构造函数在生成实例化对象时,会将自己 prototype 这个空间的地址赋值给实例化对象的 proto 来存储,两者指向同一个存储空间,可以相互调用数据。当调用实例化对象obj中fun函数时(obj.fun()),实例化对象本身中,是没有这个函数的,会继续在 proto 中寻找是否有这个方法函数 fun,proto实际上指向的就是构造函数的 prototype,构造函数的 prototype 中,是有这个方法的,那么就可以正常调用。让我们看一下控制台输出结果
在这里插入图片描述
这里,我们看一下下面这种情况
在这里插入图片描述
查看结果
在这里插入图片描述
在这里,我们先调用构造函数,是只有属性而没有方法的,因为定义方法的步骤还没有执行,从而结果报错。

3.ES6构造函数class

ES6中,新增语法形式class类,是一种新的定义构造函数的语法,作用和原理与ES5语法完全相同,只是语法格式和书写方式不同,这里我们来看一下
在这里插入图片描述
控制台查看结果
在这里插入图片描述
class 类名{},constructor是构造器,专门接收封装类时的参数和给实例化对象定义属性和属性值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值