位置: 编程技术 - 正文

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

  • 小微企业所得税税率
  • 金蝶凭证汇总表字体变小
  • 累计纳税工资是什么意思
  • 两家公司原材料能否借用
  • 小规模进项负数发票需要认证吗
  • 发生销售折让可以不开具
  • 先进制造业企业按照当期可抵扣进项税额
  • 每月能领多少专利费
  • 个人所得税核定征收计算公式
  • 技术服务发票是劳务发票吗
  • 企业拆迁补偿款要交哪些税
  • 子公司可否将母公司注销
  • 财税2009年59号解读
  • 土地增值税缴纳标准
  • 小微企业增值税税率
  • 如何增加发票数量和额度
  • 个人将房产无偿赠与他人应交个人所得税吗
  • 公司食堂支出计入什么科目
  • 个人开票给公司有什么风险
  • 路由器间歇性断网怎么解决
  • 收到安监处罚款怎么处理
  • 出口企业免抵退是什么意思
  • mac菜单栏如何调整位置
  • 来电转接怎么设置空号
  • 工商年报缴费基数是什么意思
  • 损益明细表计提企业所得税
  • php数组函数 菜鸟
  • 会计的四大基本要素
  • 世界上最贵的鼠标是用什么做的
  • laravel如何使用前端的纯静态页
  • 财政返还土地奖金的规定
  • 累计盈余科目怎么填
  • centos7完整版安装
  • yarn install报错
  • framework怎么用
  • arc架构
  • 树莓派能干什么
  • 增值税专用发票抵扣期限
  • 资产负债表没有期末数
  • 总公司与分公司合作协议范本
  • facebook/scribe · GitHub
  • syslog使用
  • mongodb应用实例
  • 有限公司分公司属于什么类型
  • 出口报关成功
  • 累计折旧的借贷方表示
  • 股东借款转为实收资本的说明
  • 税控盘服务费小规模可以抵扣吗
  • 分期收款销售的会计与纳税处理
  • 经营性租赁账务处理方法
  • 农业项目土地流转
  • 其他应收款如何做坏账处理
  • 公允价值变动损益借贷方向
  • 营业税金及附加和税金及附加有什么区别
  • SQL Server SQL Agent服务使用教程小结
  • mysql索引基础
  • windows7软件运行没反应
  • win10快速启动什么意思
  • ubuntu-desktop启动
  • centos下载与安装
  • porteus中文版下载
  • windows模拟器(可安装电脑软件)
  • tar解压工具
  • el-select tree
  • nodejsapi框架
  • nodejs读写json文件
  • js的getattribute
  • 利用JQuery实现datatables插件的增加和删除行功能
  • Node.js中的什么模块是用于处理文件和目录的
  • ajax按顺序执行
  • javascript入门教程
  • Android开发工具
  • 怎样编?
  • google年会
  • JavaScript italics方法入门实例(把字符串显示为斜体)
  • 车价36万保险一般多少钱
  • 管道运输合同需不需要缴纳印花税
  • 用于赞助的消费品需要缴纳消费税吗
  • 珠海自助征信查询机
  • 如果贸易后y产品的相对价格下降很大的话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设