位置: 编程技术 - 正文

js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式)(js面向对象编程的三大特性)

编辑:rootadmin

推荐整理分享js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式)(js面向对象编程的三大特性),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js中面向对象编程,js面向对象的三大特性,js面向对象编程实例,js面向对象和面向过程,js面向对象和面向过程,js中面向对象编程,js中面向对象,js面向对象的几种方式,内容如对您有帮助,希望把文章链接给更多的朋友!

在上篇文章给大家介绍了javascript面向对象基础,本篇文章继续深入学习javascript面向对象,JS的语法非常灵活,简单的对象创建就有好几种不同的方法。这些过于灵活的地方有时候确实很让人迷惑,那么今天我们就来梳理一下JS中常用的创建对象的几种方法吧。

前言

虽然使用 Object构造函数 或者使用 对象字面量 可以很方便的用来创建一个对象,但这种方式有一个明显的缺点:使用一个接口创建多个对象会产生很多冗余的代码。因此为了解决这个问题,人们开始使用以下几种方式来常见对象。

工厂模式

该模式抽象了创建对象的具体过程,用函数来以特定接口创建对象的细节

工厂模式测试

工厂方式的问题:使用工厂模式能够创建一个包含所有信息的对象,可以无数次的调用的这个函数。虽然其解决了创建多个相似对象的问题,但却没有解决对象识别的问题(即如何得知一个对象的类型)

构造函数模式

构造函数模式测试

注意构造函数与工厂模式有些不同的地方,如下

构造函数首字母大写

没有显式地创建对象

js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式)(js面向对象编程的三大特性)

将属性和方法赋值给了 this 对象

没有return语句

而且以这种方式来调用构造函数会大致经历一下 几个步骤

创建一个新的对象

将构造函数的作用域赋值给这个对象(因此this就指向了这个对象)

执行构造函数中的代码(即给新对象添加属性和方法的过程)

返回对象

注意:构造函数其实和普通的函数没有太大的差别,唯一的不同在于调用方式的不同。以下演示不同的几种调用方式

构造函数的问题:使用构造函数最主要的问题就是每个方法都要在每个实例上重新创建一次,p1与p2的都有show方法,但不是同一个Function的实例,因为function在js中也是一个对象。因此他们共有的show方法并不相等。

原型模式

每个函数都有一个prototype属性,这个属性是一个指针,指向一个对象。而这个对象的用途是 包含可以由 特定类型 的所有 实例 共享的属性和方法。即调用构造函数所创建的那个对象的 原型对象

好处是可以让所有对象的实例共享他的属性的方法。即无需在构造函数中定义实例的信息

以上内容是关于js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式),希望大家喜欢。

初步了解javascript面向对象 前言基于类的对象:我们都知道面向对象的语言中有一个明显的标志,就是都有类的概念,通过类这个类似模板的东西我们可以创建许多个具有相同的

JS实现兼容性较好的随屏滚动效果 本文实例讲述了JS实现兼容性较好的随屏滚动效果。分享给大家供大家参考,具体如下:代码中的参数解释如下:id你要滚动的内容的idl横坐标的位置不

JavaScript识别网页关键字并进行描红的方法 本文实例讲述了JavaScript识别网页关键字并进行描红的方法。分享给大家供大家参考,具体如下:这里演示JavaScript智能识别网页关键字并加红显示出来,

标签: js面向对象编程的三大特性

本文链接地址:https://www.jiuchutong.com/biancheng/383692.html 转载请保留说明!

上一篇:JS实现网页每隔3秒弹出一次对话框的方法(js间隔执行的代码)

下一篇:初步了解javascript面向对象(初步了解的英文)

  • 装修款需要开发票吗
  • 个人所得税隔月交么
  • 审计调整分录汇总的内容
  • 小企业商品销售的入账价格
  • 货样广告品出口需要开票吗
  • 所有的企业都能采用免费策略
  • 利润表的企业所得税怎么查询
  • 软件技术服务费算无形资产吗
  • 个人所得税违规怎么处理
  • 自然灾害造成的存货净损失计入什么科目
  • 个人所得税免税收入怎么填纳税申报表
  • 注册资本转让税率
  • 浅谈12 条用于 Linux 的 MySQL/MariaDB 安全最佳实践
  • php实验步骤
  • mac电脑键盘进水,键盘不可以用了
  • 出口退税退回的税款怎么记账
  • 金融资产减值损失计入什么科目
  • 私营公司股权转让
  • vue url 参数
  • 违反发票管理的处罚
  • 大雾笼罩的早晨
  • 金融商品转让业务包括
  • 公司哪些支出费用可以扣
  • notion all in one
  • 亚伯拉罕湖中的树,加拿大艾伯塔 (© Coolbiere/Getty Images)
  • window cuda
  • 文件上传模板怎么弄
  • 实现视图
  • linux中login命令
  • 固定资产投资账面价值
  • 小企业发票打印流程
  • 购入固定资产的进项税额可以抵扣吗
  • 技术服务费增值税税率1%
  • mongodb基本使用
  • 增值税会计账务处理例题
  • 存货和固定资产一经计提减值以后期间不得转回
  • 小规模增值税纳税人税率
  • 应交增值税明细账怎么填写样本
  • 汇总记账凭证账务处理
  • 费用发票处理
  • 以前年度多计收入今年怎么调整
  • 跨月抵扣的发票能退回吗
  • 我国消费现状分析
  • 开具信用证的费用能开专票吗
  • 收到广告费分录
  • 在施工期间,承包商可能遇到不能预见
  • 办公设备折旧年限规定多少年
  • 为什么新准则要实施
  • 外国专家经费管理办法
  • 企业名称变更后税务变更需要什么资料
  • 应收及预付款项的坏账损失应当于实际发生时计入
  • 可以自行开具增值税专用发票的行业有哪些
  • 其他应收款属于什么会计要素
  • 税收分类编码填错有影响吗
  • 科目汇总表里面要填累计折旧吗
  • 代办营业执照安全可靠吗
  • Mysql使用insert插入多条记录 批量新增数据
  • win7系统开机后黑屏只有鼠标指针可以移动
  • ubuntu16连接wifi步骤
  • UBUNTU怎么安装MPEG-4解码器
  • mac如何切换界面 快捷键
  • 手动为LiteSpeed安装eAccelerator和XCache的方法分享
  • linux的samba是什么
  • jquery 动态添加列表元素
  • 网页收集数据
  • perl sub
  • unity移动方法
  • 下列关于android的说法中,错误的是
  • 安卓icon图标
  • 深入解析java编译器:源码剖析与实例详解
  • jQuery的Ajax用户认证和注册技术实例教程(附demo源码)
  • jquery遍历li
  • jquery绑定事件和移除事件
  • node中使用什么引入模块
  • 木瓜电子
  • Android 自定义view炫酷动画
  • Protocol Buffers(Protobuf)开发者指南---概览
  • python批量填表
  • 太原市小店区电影院营业时间
  • 如何鼓励互联网企业发展
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设