位置: 编程技术 - 正文

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教程代码)

  • 可以出口的商品
  • 企业为自然人什么意思
  • 企业进项不足的原因
  • 汽油费通行费等怎么记账
  • 装修行业专票的税率是多少
  • 房屋租赁的发票备注怎么写
  • 财政部监制章可以报销吗
  • 收入与成本不配合
  • 飞机票退票费如何记账
  • 什么叫备品备件
  • 销项税普票
  • 小规模纳税人增值税税率
  • 个体开建筑服务税率多少?
  • 企业所有职工都要交税吗
  • 接受投资的固定资产账务处理
  • 房贷怎么申报抵押贷款
  • 计提与不计提短贷的区别
  • 社会组织捐款
  • 医疗机构交企业所得税吗
  • 普票6个点怎么算
  • 房地产开发公司取名
  • 企业当年发生的某些费用
  • 孵化器 怎么赚钱
  • 代数分配法适用于什么
  • 银行代发工资一定要本行卡吗
  • 败诉赔偿如何支付
  • 外国企业代表处企业所得税
  • 附加税的税率是多少2023年
  • 购买加油卡怎么充值
  • 管理费用如何分摊到产品成本
  • 单位给个人报销计入什么科目
  • system进程有什么用
  • 营业外支出与营业收入之比应小于1%的说明
  • 在XP中,为什么"网络连接"图标消失?
  • 邮件远程控制
  • 企业扣除内容有哪些
  • 应缴纳消费税会增加吗
  • 应付票据转让会计分录
  • 租赁经营账务处理办法
  • 进货发票怎么抵税
  • php使用js
  • vue中computed和watch区别
  • 财政零余额账户存款
  • 代扣代缴个人所得税手续费返还 增值税
  • 公司首次申报个人所得税
  • 权益法下公允价值变动计入其他综合收益
  • 食堂费用没有发票
  • 税控盘维护费280元怎么做账
  • 外购固定资产对公司影响
  • 购买的车位如何做账
  • 运输费计入什么科目分录
  • 宣传费税前扣除什么意思
  • 暂估入库可以隔几个月再冲回吗
  • 什么情形不属于共同犯罪
  • 企业进行长期投资的意义
  • sql 修改表的字段名称
  • ssh访问windows
  • be备份linux系统
  • windowsxp优点
  • win7系统安全软件
  • android怎么ping
  • shell脚本语言入门
  • bat脚本自动点击按钮
  • python2.7.11
  • python获取数据包
  • Javascript事件实例详解
  • 数据结构 二叉树什么是孩子数
  • sql服务3417
  • 网页制作范例
  • shell函数参数
  • javascript基础笔记
  • jQuery实现HTML表格单元格的合并功能
  • javascript静态
  • jquery判断checkbox是否选中及改变checkbox状态的实现方法
  • 湖南税务局发票查询
  • 中国税务社保缴费app下载
  • 手撕发票查询真伪平台
  • 纳税是什么税
  • 珠海的教育水平在全省的排名
  • 网上订机票怎么取票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设