分享更有价值
被信任是一种快乐

JavaScript对象的构造函数和new操作符怎么用

文章页正文上

本篇内容主要讲解“JavaScript对象的构造函数和new操作符怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript对象的构造函数和new操作符怎么用”吧!前文讲到的对象创建方法都是直接使用let obj = {...}语法,具体方法如下:这样的对象创建方法虽然简单又直接,但是对象的代码无法重用,在创建很多类似对象时,代码量会很高。此时,就需要使用构造函数,和new操作符实现相似对象的构建。如果学习过其他面向对象语言的童鞋对构造方法应该都不陌生,尤其是学习C++的童鞋应该印象会非常深刻。在其他面向对象的语言中,构造函数通常是这样定义的:构造函数是一个特殊的成员函数,名字与类名相同,创建类类型对象时由编译器自动调用,保证每个数据成员都有一个合适的初始值,并且在对象的生命周期内只调用一次。我们可以简单的理解为,构造函数是所有对象的成员方法中,最早被调用的那个。常用于初始化对象的状态,例如人的名字、火车的节数等。和构造函数对应的是析构函数,析构函数是所有对免费云主机、域名象的成员方法中,最后被调用的那个,常常是对象失去存在价值,用于回收对象资源。一个对象从创建到回收,总共可以划分为3个阶段,如下图:其中,对象创建阶段的主要工作由构造函数完成,包括对象的初始化,关系的连接等。执行阶段主要是对象功能的调用,用于配合整个项目的执行,通常由普通函数(对象的成员函数)完成。销毁阶段由析构函数接手,用于清除对象占用的内存空间,防止内存泄漏的发生。相比于其他面向对象语言,JavaScript对象的构造函数比较特殊,它可以是任何一个普通的函数,而且无需在对象中定义。只有两个约定:构造函数的命名通常以大写开头;构造函数智能由new操作符执行;例如:以上代码中的People函数就可以当作构造函数使用,同时它也是一个普通的函数。对象的this指针章节,我们介绍过,如果一个普通函数中使用thisthis的内容取决于调用它的对象(obj.func()),如果不使用对象调用函数,那么this在非严格模式下就是Window,严格模式下就是undefined。通常情况下,直接调用构造函数会得到不正确的结果,如果我们希望把函数当作构造函数调用,就需要使用一个新的关键字new。以下代码使用new关键字创建了两个People对象:以下是代码的执行结果:当使用new调用一个函数时,这个函数就会变成构造函数,此时,引擎就会执行以下动作:创建一个新的空对象{ },并把空对象赋值给this;执行构造函数体,通常会通过this构造对象的内部结构;返回this的值;你没有看错,使用new调用函数后,函数是有返回值的,即使在定义函数时没有return语句。代码new People('xiaoming')所做的事情大概类似以下代码:所以使用new调用构造函数后,得到的是一个由构造函数塑造过的对象。使用new关键字的好处是,我们可以书写一次构造函数代码,然后在任意的地方创建类似的对象。例如:想象一下,如果对象的代码有上百行,这么做是不是比{...}方式要简便很多呢?这就是面向对象中的代码服用,可以极大程度上降低代码量,提高开发速度。如果构造函数没有参数,我们可以省略调用时的括号:但是个人推荐不要使用这种特性,仅仅是告知在规范中存在这种语法。强调:从技术上讲,任何函数(除了箭头函数,它没有自己的 this)都可以用作构造器。即可以通过 new 来运行,它会执行上面的算法。“首字母大写”是一个共同的约定,以明确表示一个函数将被使用 new 来运行。如果我们只希望对象被创建一次,那么就可以简化构造函数的定义,使用new直接调用匿名函数,创建一个对象:代码的执行结果如下:使用匿名函数当作构造函数的结果和常规构造函数没有任何区别,唯一的区别是匿名构造函数不能重复调用(因为没有名字)。这种使用方法常用在无需复用代码的场景中。常规情况下,构造函数不需要使用return语句,它的唯一用途就是把对象的属性写入this,然后直接默认返回this对象就好了。但是,由于JavaScript对构造函数几乎没有任何约束,如果我们在一个普通函数中写了返回语句,会发生什么呢?引擎会做下面两个选择:如果return返回的是一个对象,就返回这个对象,不再返回this;如果return返回的是一个基础类型,则忽略返回语句,继续返回this;从引擎的处理方式中不难看出,构造函数的主要任务就是创建对象,处理并返回,如果使用构造函数返回一个基础类型,是没有意义的。举个栗子:代码执行结果如下:可以看出,name为’xiaoming’的对象没有被返回,而是Nobody对象代替了xiaoming。如果使用return返回一个基础类型,案例如下:代码执行结果如下:可见,在返回基础类型时,return语句是不生效的。强调:通常对象的构造函数没有返回值,我们也没有必要利用引擎对构造函数返回值的特殊处理,编写特别的构造函数。在构造函数中不仅可以添加对象的属性,由于JavaScript的函数同样可以赋值给变量,我们还可以用构造函数初始化对象的成员方法。例如,我们可以给People对象增加一个sing方法:以上代码在构造函数中为对象添加了一个方法,代码执行结果如下:到此,相信大家对“JavaScript对象的构造函数和new操作符怎么用”有了更深的了解,不妨来实际操作一番吧!这里是云技术网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

相关推荐: react如何实现数组求和

这篇“react如何实现数组求和”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“react如何实现数组求和”文章吧。 react实现数组求和的方法…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册