JavaScript构造函数原理及实现流程解析


Posted in Javascript onNovember 19, 2020

在学习构造函数之前我们需要知道我们学习构造函数需要学习什么:

1.什么是构造函数

2.构造函数用来做什么

3.构造函数的执行过程

4.构造函数的返回值

1.所以首先我们需要知道什么是构造函数:

在我看来,构造函数具有两个特点可以判断是否为构造函数:

1.当函数名为首字母大写时,这个是一个可以大概判断构造函数与普通函数的一个特点,但是不是绝对正确,因为普通函数也可以是大写字母开头

2.当我们需要调用构造函数时我们需要new <构造函数>,也就是产生一个实例化对象。

function Student(name,age,sex,height){
      this.name=name;
      this.age=age;
      this.sex=sex;
      this.height=height;
    }
    //调用构造函数,也就是实例化一个对象。
    var p=new Student('luke',23,'nan',180)
    console.log(p);

控制台输出:

JavaScript构造函数原理及实现流程解析

可以看出输出的是一个对象

2.构造函数是用来做什么的:

1.当我们平时创建对象时可能会用如下创建对象的方式来创建,上代码:

//用创建对象方式来创建
     var stu1={name:'zs',age:20,sex:"male",height:186};
     var stu2={name:'ls',age:21,sex:"male",height:180}
     var stu3={name:'ww',age:22,sex:"female",height:156}
     var stu4={name:'jx',age:23,sex:"female",height:165}
     var stu5={name:'xf',age:24,sex:"male",height:180}

2.当我们用构造函数来创建这个对象时:

//用构造函数来创建对象
    function Student(name,age,sex,height){
      this.name=name;
      this.age=age;
      this.sex=sex;
      this.height=height;
    }
     var stu1=new Student('zs',20,"male",186);
     var stu2=new Student('ls',21,"male",180);
     var stu3=new Student('ww',22,"female",156);
     var stu4=new Student('jx',23,"female",165);
     var stu5=new Student('xf',24,"male",180);

这样看起来是不是要简洁的多呢,这里因为只有五个人,要是五六十个就会看出明显效果

3.构造函数的执行过程

在前面我们知道了构造函数是什么,和其作用,也通过代码来看出了构造函数的作用。那我现在我们需要知道构造函数的执行过程,因为学习一个东西我们需要学习其原理,而不是其表面

所以接下来我就来讲一讲构造函数的执行过程:

在之前我们都知道,要调用构造函数我们需要在其前面加一个new关键字,所以主要就是new在其作用,在执行new关键字后,很明显,他跟以往的函数调用就不同了,他会依次执行以下步骤:

1.new过后会产生一个空对象,作为一个返回的对象实例

2.将空对象的原型指向了构造函数的prototype属性

3.将空对象的值赋值给构造函数里面的this值

4.开始执行构造函数里的代码

4.构造函数的返回值

知道了其执行过程,显而易见,new关键字创建的实例对象为构造函数的返回值。

其实这是不对的,哈哈。

返回值需要分情况来定:

1.当函数中没有return来返回值的时候,会返回this,也就是实例化对象。就像在说2.构造函数有什么作用时说的一样

2.当函数中return中返回一个复杂类型数据的时候,构造函数会返回这个复杂类型数据,上代码:

function Student(name,age,sex,height){
      this.name=name;
      this.age=age;
      this.sex=sex;
      this.height=height;
      return {name:'fanhui',weight:60}
    }
     var Stu1=new Student('zs',20,"male",186);
     console.log(Stu1);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
IE6-IE9中tbody的innerHTML不能赋值的解决方法
Jun 05 Javascript
js调用webservice构造SOAP进行身份验证
Apr 27 Javascript
AngularJS实现ajax请求的方法
Nov 22 Javascript
微信小程序开发(二)图片上传+服务端接收详解
Jan 11 Javascript
浅谈javascript的闭包
Jan 23 Javascript
JavaScript纯色二维码变成彩色二维码
Jul 23 Javascript
Angular 4根据组件名称动态创建出组件的方法教程
Nov 01 Javascript
微信小程序实现的点击按钮 弹出底部上拉菜单功能示例
Dec 20 Javascript
微信小程序学习笔记之表单提交与PHP后台数据交互处理图文详解
Mar 28 Javascript
layui2.0使用table+laypage实现真分页
Jul 27 Javascript
解决vue项目刷新后,导航菜单高亮显示的位置不对问题
Nov 01 Javascript
js实现圆形菜单选择器
Dec 03 Javascript
javascript this指向相关问题及改变方法
Nov 19 #Javascript
JavaScript实现alert弹框效果
Nov 19 #Javascript
Vue 打包的静态文件不能直接运行的原因及解决办法
Nov 19 #Vue.js
如何使用 vue-cli 创建模板项目
Nov 19 #Vue.js
原生js实现自定义消息提示框
Nov 19 #Javascript
原生js实现点击按钮复制内容到剪切板
Nov 19 #Javascript
jQuery-App输入框实现实时搜索
Nov 19 #jQuery
You might like
解析PHP中常见的mongodb查询操作
2013/06/20 PHP
ThinkPHP使用心得分享-分页类Page的用法
2014/05/15 PHP
关于二级域名下使用一级域名下的COOKIE的问题
2011/11/07 Javascript
jquery选择器的选择使用及性能介绍
2013/01/16 Javascript
Jquery实现鼠标移上弹出提示框、移出消失思路及代码
2013/05/19 Javascript
如何动态的导入js文件具体该怎么实现
2014/01/14 Javascript
javascript自动给文本url地址增加链接的方法分享
2014/01/20 Javascript
raphael.js绘制中国地图 地图绘制方法
2014/02/12 Javascript
nodejs npm package.json中文文档
2014/09/04 NodeJs
javascript引用赋值(地址传值)用法实例
2015/01/13 Javascript
JavaScript实现瀑布流布局
2020/06/28 Javascript
JavaScript实现简单的四则运算计算器完整实例
2017/04/28 Javascript
微信小程序 navbar实例详解
2017/05/11 Javascript
微信小程序 实现点击添加移除class
2017/06/12 Javascript
jquery+css实现侧边导航栏效果
2017/06/12 jQuery
js将键值对字符串转为json字符串的方法
2018/03/30 Javascript
javascript、php关键字搜索函数的使用方法
2018/05/29 Javascript
JavaScript实现淘宝京东6位数字支付密码效果
2018/08/18 Javascript
vue微信分享出来的链接点开是首页问题的解决方法
2018/11/28 Javascript
Vue表单控件绑定图文详解
2019/02/11 Javascript
基于vue开发微信小程序mpvue-docs跳转页面功能
2019/04/10 Javascript
vuex vue简单使用知识点总结
2019/08/29 Javascript
24行JavaScript代码实现Redux的方法实例
2019/11/17 Javascript
Tornado服务器中绑定域名、虚拟主机的方法
2014/08/22 Python
python分割一个文本为多个文本的方法
2019/07/22 Python
Flask处理Web表单的实现方法
2021/01/31 Python
市场营销专业大学生职业生涯规划文
2014/03/06 职场文书
绿色学校实施方案
2014/03/31 职场文书
创业培训计划书
2014/05/03 职场文书
初三学生语文考试作弊检讨书
2014/12/14 职场文书
2015年员工工作表现评语
2015/03/25 职场文书
《赵州桥》教学反思
2016/02/17 职场文书
先进党支部事迹材料2016
2016/02/26 职场文书
青年岗位能手事迹材料(2016推荐版)
2016/03/01 职场文书
Redis读写分离搭建的完整步骤
2021/09/14 Redis
Java数据开发辅助工具Docker与普通程序使用方法
2021/09/15 Java/Android