位置: 编程技术 - 正文

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

  • 账本印花税的计税依据
  • 个人去税务局开专票需要提供什么
  • 城市维护建设税优惠政策
  • 年报资金数额要怎样填
  • 进口增值税完税证明
  • 融资租出的设备计入什么科目
  • 门票可以直接入账吗
  • 政府非税收入的种类
  • 其他应收款有什么业务
  • 电子承兑汇票付款流程
  • 上个月的进项发票可以这个月勾选吗
  • 税务管理相关知识
  • 固定资产评估是什么单位
  • 免税发票可以抵多少税
  • 三方协议是先签先干活
  • 出口企业增值税优惠政策
  • 怎样预交增值税
  • 文化事业建设费减免政策
  • 增值税附加税包含哪些税
  • 免抵退转免税
  • 企业账面库存过大应怎样处理好
  • 工业企业采购原材料
  • 跨年度专用发票如何开红字发票
  • 保险车辆折旧的计算方法有哪些
  • 小规模付增值税怎么做账
  • 福利费不属于工资
  • 现金收付业务流程图
  • 公司向法人借款会计分录
  • 关于获得政府补助的公告
  • 房地产企业困境
  • win10电源和睡眠设置不起作用
  • phpstorm ftp
  • PHP:pg_result_error()的用法_PostgreSQL函数
  • 临时用工怎样做账
  • 营改增后固定资产报废处置收入计税
  • vue调整图标大小
  • laravel模板引擎
  • 3d检测软件
  • php文件上传用什么请求方法
  • 网页视频不显示画面
  • 给深度学习研究生的入门建议(未完待续ing)
  • node.js解决跨域请求
  • 成本核算的五个要求
  • 机器人折旧年限
  • 罚款是否需要开证明
  • 个人所得税经营所得
  • python迭代器有什么用
  • 数字黑洞有哪些
  • mysql binlog详解
  • 记账凭证装订好了如何在拆开
  • Mysql以utf8存储gbk输出的实现方法提供
  • 租办公室自己装修可以拆走吗
  • 科目余额表平是什么情况
  • 发票跨年冲红怎么做账
  • 实名汽车票抵扣
  • 发现错账后进行错账更正的方式
  • 股东参与经营可以退股吗
  • 投资性房地产的范围
  • 数据库日期要加引号吗
  • solaris syslog
  • windows有哪些
  • windows十桌面
  • windows英文版本
  • ubuntu zed
  • linux与windows有哪些主要区别
  • win10如何彻底关掉自动锁屏
  • -f linux命令
  • win8怎么设置自启动
  • win10天气组件
  • nodejs实现文件压缩下载
  • bat vba
  • android定时器的使用
  • Python中强大的命令行库click入门教程
  • 朵朵舞百科
  • bootstrap js插件
  • 每月个人所得税申报截止时间是几号
  • 中国税务社保缴费app下载
  • 北京西城税务局
  • 中介服务企业怎么注册
  • 一般纳税人办理退税流程及手续
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设