位置: 编程技术 - 正文

深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解(深入理解新发展理念)

编辑:rootadmin

推荐整理分享深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解(深入理解新发展理念),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入理解javascript,深入理解新发展理念,推进供给侧结构性改革 心得体会,深入理解javascript,深入理解计算机系统,深入理解新发展理念,推进供给侧结构性改革,深入理解计算机系统,深入理解javascript特性,深入理解javascript,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

本章我们要讲解的是S.O.L.I.D五大原则JavaScript语言实现的第5篇,依赖倒置原则LSP(The Dependency Inversion Principle )。

英文原文: High-level modules should not depend on low-level modules. Both should depend on abstractions. 高层模块不应该依赖于低层模块,二者都应该依赖于抽象

B. Abstractions should not depend upon details. Details should depend upon abstractions. 抽象不应该依赖于细节,细节应该依赖于抽象依赖倒置原则的最重要问题就是确保应用程序或框架的主要组件从非重要的底层组件实现细节解耦出来,这将确保程序的最重要的部分不会因为低层次组件的变化修改而受影响。

该原则的第一部分是关于高层模块和低层模块之间的耦合方式,在传统的分成架构中,高层模块(封装了程序的核心业务逻辑)总依赖于低层的一些模块(一些基础点)。当应用依赖倒置原则的时候,关系就反过来了。和高层模块依赖于低层模块不同,依赖倒置是让低层模块依赖于高层模块里定义的接口。举例来说,如果要给程序进行数据持久化,传统的设计是核心模块依赖于一个持久化模块的API,而根据依赖倒置原则重构以后,则是核心模块需要定义持久化的API接口,然后持久化的实现实例需要实现核心模块定义的这个API接口。

该原则的第二部分描述的是抽象和细节之间的正确关系。理解这一部分,通过了解C++语言比较有帮助,因为他的适用性比较明显。

不像一些静态类型的语言,C++没有提供一个语言级别的概念来定义接口,那类定义和类实现之间到底是怎么样的呢,在C++里,类通过头文件的形式来定义,其中定义了源文件需要实现的类成员方法和变量。因为所有的变量和私有方法都定义在头文件里,所以可以用来抽象以便和实现细节之前解耦出来。通过定只定义抽象方法来实现(C++里是抽象基类)接口这个概念用于实现类来实现。

DIP and JavaScript

因为JavaScript是动态语言,所以不需要去为了解耦而抽象。所以抽象不应依赖于细节这个改变在JavaScript里没有太大的影响,但高层模块不应依赖于低层模块却有很大的影响。

在当静态类型语言的上下文里讨论依赖倒置原则的时候,耦合的概念包括语义(semantic)和物理(physical)两种。这就是说,如果一个高层模块依赖于一个低层模块,也就是不仅耦合了语义接口,也耦合了在底层模块里定义的物理接口。也就是说高层模块不仅要从第三方类库解耦出来,也需要从原生的低层模块里解耦出来。

深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解(深入理解新发展理念)

为了解释这一点,想象一个.NET程序可能包含一个非常有用的高层模块,而该模块依赖于一个低层的持久化模块。当作者需要在持久化API里增加一个类似的接口的时候,不管依赖倒置原则有没有使用,高层模块在不重新实现这个低层模块的新接口之前是没有办法在其它的程序里得到重用的。

在JavaScript里,依赖倒置原则的适用性仅仅限于高层模块和低层模块之间的语义耦合,比如,DIP可以根据需要去增加接口而不是耦合低层模块定义的隐式接口。

为了来理解这个,我们看一下如下例子:

在上述代码里,有个小型的JS类库将一个DIV转化成Map以便显示当前跟踪的位置信息。trackMap函数有2个依赖:第三方的Google Maps API和Location feed。该feed对象的职责是当icon位置更新的时候调用一个callback回调(在初始化的时候提供的)并且传入纬度latitude和精度longitude。Google Maps API是用来渲染界面的。

feed对象的接口可能按照装,也可能没有照装trackMap函数的要求去设计,事实上,他的角色很简单,着重在简单的不同实现,不需要和Google Maps这么依赖。介于trackMap语义上耦合了Google Maps API,如果需要切换不同的地图提供商的话那就不得不对trackMap函数进行重写以便可以适配不同的provider。

为了将于Google maps类库的语义耦合翻转过来,我们需要重写设计trackMap函数,以便对一个隐式接口(抽象出地图提供商provider的接口)进行语义耦合,我们还需要一个适配Google Maps API的一个实现对象,如下是重构后的trackMap函数:在该版本里,我们重新设计了trackMap函数以及需要的一个地图提供商接口,然后将实现的细节挪到了一个单独的googleMapsProvider组件,该组件可能独立封装成一个单独的JavaScript模块。如下是我的googleMapsProvider实现:做了上述这些改变以后,trackMap函数将变得非常有弹性了,不必依赖于Google Maps API,相反可以任意替换其它的地图提供商,那就是说可以按照程序的需求去适配任何地图提供商。

何时依赖注入?

有点不太相关,其实依赖注入的概念经常和依赖倒置原则混在一起,为了澄清这个不同,我们有必要来解释一下:

依赖注入是控制反转的一个特殊形式,反转的意思一个组件如何获取它的依赖。依赖注入的意思就是:依赖提供给组件,而不是组件去获取依赖,意思是创建一个依赖的实例,通过工厂去请求这个依赖,通过Service Locator或组件自身的初始化去请求这个依赖。依赖倒置原则和依赖注入都是关注依赖,并且都是用于反转。不过,依赖倒置原则没有关注组件如何获取依赖,而是只关注高层模块如何从低层模块里解耦出来。某种意义上说,依赖倒置原则是控制反转的另外一种形式,这里反转的是哪个模块定义接口(从低层里定义,反转到高层里定义)。

总结

这是五大原则的最后一篇了,在这5篇文字里我们看到了SOLID如何在JavaScript里实现的,不同的原则在JavaScript里通过不同的角度来说明的。(大叔注:其实大叔觉得虽然是有点不伦不类,但从另外一个层面上说,大体的原则在各种语言上其实还是一样的。)

深入理解JavaScript系列():S.O.L.I.D五大原则之接口隔离原则ISP详解 前言本章我们要讲解的是S.O.L.I.D五大原则JavaScript语言实现的第4篇,接口隔离原则ISP(TheInterfaceSegregationPrinciple)。英文原文:

PHP 数组current和next用法分享 1.currentphp$transport=array('foot','bike','car','plane');$mode=current($transport);//$mode='foot';$mode=next($transport);//$mode='bike';$mode=current($transport);//$mode='bike';$mode=prev($transport)

PHP守护进程实例 php也是可以直接进行守护进程的启动与终止的,相对于shell来说会简单很多,理解更方便,当然了php的守护进程要实现自动重启还是要依赖于shell的crontab

标签: 深入理解新发展理念

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

上一篇:Redis基本知识、安装、部署、配置笔记(redis基础教程)

下一篇:深入理解JavaScript系列(21):S.O.L.I.D五大原则之接口隔离原则ISP详解(深入理解中国式现代化)

  • 挂靠别的公司都需要交什么税
  • 餐饮行业的成本率在多少才正常
  • 去年工资计提错误,今年如何修改
  • 补缴以前年度增值税如何做账
  • 车船税保险公司会不会多收
  • 收款和出库哪个借方哪个贷方?
  • 经营所得税投资者减除费用
  • 一般纳税人所得税是季报还是月报
  • 领料投入生产会计分录
  • 缴纳税费及工会经费
  • 境外保险是什么意思
  • 印花税的滞纳金怎么计算
  • 公司注销了之后银行账户还能用吗
  • 免征增值税转入什么科目
  • 营改增后兼营非应税劳务的税务处理怎么做?
  • 支付国外佣金代扣代缴企业所得税怎样记账
  • 防伪税控技术维护费怎么申报
  • mac应用程序安装权限在哪找
  • 谷歌浏览器adobe flash player已不再支持
  • w10电脑很卡
  • 自建用地是什么性质
  • 事业单位工会经费会计账务处理办法
  • 残保金必须交社保才能领吗
  • 房屋租赁收入确认条件新准则
  • 固定资产折旧计提时间
  • linux中的应用程序主要保存在哪些目录中
  • 骑自行车的好处功效与作用
  • 简述项目融资风险的内容
  • GrooveMonitor.exe是什么进程?GrooveMonitor.exe可以禁用卸载吗?
  • 计算机与自动化的关系
  • PHP:imagetypes()的用法_GD库图像处理函数
  • 职工教育经费列支范围规定
  • 商铺转让权是什么意思
  • 珠穆朗玛峰的壮观
  • vue设置宽度
  • php生成随机字母数字代码
  • Yii2 rbac权限控制之rule教程详解
  • 层层剖析的近义词
  • php隐藏图片地址
  • 增值税发票丢失罚款多少
  • set nu命令
  • 初级会计直线法摊销
  • 将本月发生的制造费用总额按生产工人
  • 金税盘开票系统复核人员设置在哪里
  • 转让全部探明矿权合法吗
  • 缴纳文化事业建设费
  • 未分配利润与净利润有关系吗
  • 利润总额包括的内容主要有
  • 收到以前年度退回的企业所得税怎么做账
  • 上级补助收入是指事业单位从主管部门和上级单位取得的
  • 一般纳税人不得领用专票的情形
  • 转账支票记到哪个科目
  • 印花税的征税对象有哪些
  • 什么是结构性存款基金
  • 结转成本的方法有几种
  • 委托设置什么意思
  • MySQL主从同步原理介绍
  • mysql 5.7.22安装教程
  • 哪个是win8.1更新win10的补丁
  • win7不能复制文件怎么办
  • ubuntu kylin 14.04下载 ubuntu优麒麟14.04 lts下载地址
  • 第三方win7系统哪个最好
  • bzip2 bunzip2 bzcat参数使用
  • win8wifi设置在哪
  • jquery炫酷效果
  • unity的脚本
  • c#的程序集
  • android自定义样式
  • data命令
  • 原生javascript+css3编写的3D魔方动画旋扭特效
  • js中的表达式是什么
  • sed基本用法
  • android activity回调函数
  • javascriptj
  • jquery操作样式的方法
  • android:theme="@style/apptheme"
  • 全国低保查询系统网站
  • 国家税务局申请电子发票怎么申请
  • 山东2022新生儿数量统计表
  • 作废的发票验旧之后怎么领取新发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设