马上加入IBC程序猿 各种源码随意下,各种教程随便看! 注册 每日签到 加入编程讨论群

C#教程 ASP.NET教程 C#视频教程程序源码享受不尽 C#技术求助 ASP.NET技术求助

【源码下载】 社群合作 申请版主 程序开发 【远程协助】 每天乐一乐 每日签到 【承接外包项目】 面试-葵花宝典下载

官方一群:

官方二群:

js工厂函数创建对象与对象构造函数的理解

[复制链接]
查看2412 | 回复0 | 2019-8-14 13:25:08 | 显示全部楼层 |阅读模式
工厂函数,顾名思义,就是通过一个"工厂的加工" 来创建一个函数
  1. //工厂函数 function createPerson(name,sex){     sex = sex == '男' ? '女' : sex  // '加工'    return {         name:name,         sex:sex     }; } var p =createPerson('张三','男');
复制代码
133006imexuchaend65zn8.png


这种操作在需要创建多个相似对象时可以有用地减少重复代码,但是这样有个缺点就是,每次调用工厂函数创建的对象都是独立的object,不存在继承关系,显然,这样的面向对象编程失去了灵魂

于是, 对象构造函数就出现了
  1. //构造函数 function Person(name,sex){ //留意:构造函数函数名首字母要大写, 用以区别普通函数    this.name = name;     this.sex = sex } var p = new Person('张三','男');
复制代码
使用构造函数有几个要留意的点

1.构造函数创建的对象的constructor对象引用的是该构造函数, 即
  1. p.constructor === Person //true
复制代码

2.在调用构造函数时要使用new关键字,在使用了new关键字后,内部举行了四个步骤:
  - 构造函数创建一个空对象
  - 构造函数里的this指向该空对象
  - 空对象的内部原型指向构造函数的原型对象
  - 构造函数执行完之后, 如果没有return的话, 就把该空对象返回
133006d04x40y4z4ly4oxb.png



3.如果不使用new 关键字,调用构造函数时,就会当成普通的函数调用,里面的this 指向的就是window,且如果没有return就不会返回;

来源:https://www.cnblogs.com/aukocharlie/archive/2019/08/14/11351087.html
*滑块验证:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则