位置: 编程技术 - 正文

JavaScript设计模式初探(js 设计模式)

编辑:rootadmin

推荐整理分享JavaScript设计模式初探(js 设计模式),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js设计模式书,js设计模式应用,js 设计模式,js的设计模式,js设计模式有什么用,js设计模型,JAVASCRIPT设计模式与开发实践,javascript 设计,内容如对您有帮助,希望把文章链接给更多的朋友!

目的:设计模式众多,尝试记录下学到的不同设计模式的优劣,方便以后查阅。

前言:半年前看高程的时候看到设计模式这章,云里雾里,不是看不明白,而是不明白为啥要如此麻烦只为创建一个对象。直到最近完成了自己第一个小项目,才体会到当代码量多起来时没有适当的规范与限制是多么大的灾难。于是重新翻开高程,总结下几种我学到的简单设计模式的优劣。

正文:本文一共介绍7种设计模式以及他们的应用场景、优劣。

1.工厂模式

直接用函数来封装对象,将对象作为返回值。

缺点:对象识别的问题,所有创建出的对象都是Object的实例,不好区分。

2.构造函数模式

优点:运用构造函数模式可以将实例标示为一种特定的类型。

缺点:创建的对象的方法都是私有的,如果只是想产生公用的方法,会造成不必要的性能浪费。

3.原型模式

利用原型链继承

缺点:所有属性和方法被实例共享。当属性、方法中包含引用类型的值时,修改一个实例的属性、方法会影响所有其他实例。

JavaScript设计模式初探(js 设计模式)

4.原型+构造函数模式

私有属性、方法用构造函数产生,公有属性、方法用原型来继承。融合两种方法的优点。

缺点:注意引用类型值的原型继承。

ps:上图代码重写了Person构造函数的原型对象,将原型对象指针指向了一个对象,所以constructor属性此时指向Object而不是Person,所以要显式的将其设置成Person。

5.动态原型模式

本质上还是构造函数,只在指定方法不存在时在原型对象中添加他。

缺点:不能使用对象字面量重写原型对象。因为这会使实例的指针指向新的原型对象。也就是说上图中原型对象中添加的sayName方法会失效。

6.寄生构造函数模式

调用时使用new操作符,除此以外我看不出和工厂模式有什么区别。望高人指点。

7.稳妥构造函数模式

没有公共属性,禁用this,仅暴露必须的API用于数据调用。适用于对安全有需求的领域。

如上代码,只能通过sayName方法才能访问到内部的name属性。

本文给大家介绍了七种设计模式,分别介绍了他们的优缺点,希望对学习js设计模式相关知识有所帮助。

基于JavaScript代码实现兼容各浏览器的设为首页和加入收藏 现在的浏览器越来越多,这就使得网页设计的兼容性要求越来越高,像常用的设为首页、加入收藏代码,一般的虽然简洁,但兼容性却非常不好,加入

基于JavaScript实现通用tab选项卡(通用性强) 选项卡在大量的网站都有应用,虽然形式各有不同,但是索要达成的目的都是一样的,一般都是为了进行分类或者节省网页空间只用,算是一件利器,

实例详解JSON数据格式及json格式数据域字符串相互转换 JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。JSON采用完全独立于语言的文本格式,这些特性使JSON成为理想的数据交换语言。易于人阅读和编写

标签: js 设计模式

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

上一篇:JavaScript类型系统之Object详解(javascript类定义)

下一篇:基于JavaScript代码实现兼容各浏览器的设为首页和加入收藏(javascript教程代码)

  • 收到增值税发票怎么认证
  • 政府奖励收入要交企业所得税么
  • 已经作废的发票还需要申报吗
  • 留抵税额账上比申报表多280
  • 代扣代缴个税对企业所得税的影响
  • 已经勾选确认的发票可以取消认证吗
  • 财务月末结转成什么账户
  • 无形资产建造期间的摊销记在哪里
  • 承租人与出租人签订了一份租赁合同,该设备
  • 商业企业购入商品会计分录
  • 集资建房出租收入如何缴纳个税
  • 企业搬迁补偿款发放流程
  • 预付款对应的会计科目
  • 地产公司代办房产证
  • 企业实际发生的与取得收入有关的、合理的支出,包括
  • 营改增后还有企业所得税吗?
  • 一般纳税人开3个点的票不能抵扣进项
  • 2020年职工福利费扣除比例
  • 夫妻双方交契税可以一人到嘛
  • 应交税费 减免税款
  • 起诉销售
  • 带息商业汇票的利息分录?
  • 技术合同的计税依据包括研究开发经费
  • 贴现利息会计处理
  • 网吧登录qq安全吗
  • 由于找不到msvcr120.dll,无法继续执行代码什么意思
  • php更新数据
  • 存货报废的税务处理及会计处理
  • 其他应收款
  • 所得税年度报表资产总额
  • 密歇根湖怎么读
  • 一般纳税人向小规模纳税人开专票
  • 迭代器,生成器
  • 第二季度企业所得税怎么算出来
  • php面向过程
  • 最常用的基金业务
  • vant weapp官方文档
  • ijk解码是什么意思
  • 持有期间公允价值变动的科目归属
  • 所得税的季末从哪里算
  • 小规模纳税人减按1%账务处理
  • 在建工程减值准备是否可以转回
  • 个人佣金收入怎样交税
  • 劳务派遣申报表附表一怎么填
  • 交易性金融资产入账价值怎么计算
  • 采购流程内容
  • 财政部关于印发财政专户管理办法的通知
  • 弥补以前年度亏损怎么算
  • 会计费用类科目明细
  • 企业取得的跨期业务
  • 建筑设计行业收费标准
  • 税费多一分钱怎么调回来?
  • 土地收储款是谁给谁
  • 预付账款的账务处理过程
  • 已经入库的商品出库了要怎么做会计分录
  • 如何在电子税务局变更办税人员
  • 子公司的取得方式
  • 会计建账的内容
  • sql中的非逻辑
  • sqlserver怎么删除字段
  • win8怎么扩展c盘
  • 任务栏安全中心的图标没有了
  • win8系统怎么查看隐藏文件
  • win10系统如何关闭窗口特效
  • ip冲突不能上网怎么解决
  • windows8启动项在哪里
  • ubuntu20.04.1安装
  • win7操作技巧
  • 如何解决老电脑卡顿问题
  • win7系统咋样
  • cocos2d setTextureRect用法
  • pycharm远程调试linux
  • css如何用
  • python的导入
  • android sql语句
  • android profiler内存分析
  • jQuery 判断复选框是否选中
  • 贵州省税务网上缴费平台
  • 司法拍卖车免除扣分吗
  • 公司给个人买房,怎么做账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设