定义:高层模块不应该依赖低层模块,二者都应该依赖其抽象;抽象不应该依赖细节;细节应该依赖抽象。(百科全书)
这个定义什么意思,太专业 感觉不像人话。。
什么叫高层模块,什么叫底层模块,什么叫抽象,什么叫细节,来画图
上边这个图是遵守了依赖倒置的,再放一个不遵守的
抽象说白了就是对于细节而言比如说
交通工具是抽象,而公交车、单车、火车等就是细节了 也叫具象,当人和你说把我的交通工具拿过来,你可能在想什么交通工具,所以说
抽象就是你只知道一个概念,但是你不知道他具体是什么
细节呢,就是具体实现他对应的抽象的那么一个实例 下边放代码
// 吃的抽象类
class eat {
go() {
console.log("吃了一个什么")
}
}
//实现类(细节)
class apple extends eat {
go() {
return "吃了一个苹果"
}
}
class banana extends eat {
go() {
return "吃了一个香蕉"
}
}
class bigApple extends eat {
go() {
return "吃了十个苹果"
}
}
//人类
class people {
constructor(name) {
this.name = name
}
gotoEat(food) {
console.log(this.name, food.go())
}
}
apple = new apple
banana = new banana
bigApple = new bigApple
peopleA = new people("小明")
peopleB = new people("很饿的大明")
peopleA.gotoEat(apple)
peopleA.gotoEat(banana)
peopleB.gotoEat(bigApple)
个人认为如果没有遵守依赖倒置原则的话 那么必然没有遵守开闭原则,后果就是代码耦合严重,不易维护。
以上如果有讲的不对或不足之处,请大家批评指正
原文地址:https://www.cnblogs.com/netUserAdd/p/10436694.html
先说说大家平时最苦恼的设计稿还原度问题,一个视觉超赞的稿子,怎么到了前端手里,字体边距就乱七八糟呢?为什么没对齐,为什么没加粗,还有说好的动效怎么都没上,完全不是情感化设计了啊。
网页设计需要注意什么?在不同设备上采用相似的设计,导航的设计要简单易用、清晰明了,改变访问过的链接的颜色,让页面浏览变得更容易,仔细检查所有的链接,确保能点击的元素让用户看起来就能点击、不要让促销广告遮住内容
好的设计能够帮助企业提升数据,同时还可以提供用户一个良好的使用体验。不过今天讨论的重点并不是付费报告,而是这69条设计原则。
User Experience Design(用户体验设计),简称UED。UED是以用户为中心的一种设计手段,以用户需求为目标而进行的设计。以用户为中心的设计, 英文叫做User-Centered Design 缩写为UCD,他是UED的一种具体的设计实现理念。
这篇文章是关于Javascript的面向对象的程序设计,主要从三个方面来介绍,1. 理解对象属性; 2. 理解并创建对象; 3. 理解继承
模式化的设计套路之所以为广大网页设计师所喜爱,很大程度上是因为它们具备有良好的可用性和可访问性,在转化率和用户留存率上有着不错的数据表现。但是这些通过数据来体现的设计模式,在用户的视角里,可能并不那么理想。
初次接触或者想要进入网页设计行业的朋友会经常分不清楚web前端与网页设计之间的区别,不知道网页设计要学什么,web前端要学什么,因此感到很迷茫?
分享一些和设计师成为好朋友的个人经验,注意,这些经验技巧只适用于技术开发人员。如果有事情找设计师商量,千万不要站在设计师的背后
设计系统的产生是为了某领域内产品在不同平台和设备上都保持设计和交互风格的统一。既然是一个系统 ,那必须具有相应的完整性,它为产品设计,产品内容等方面提供相应的指导
其实Material Design的扁平化icon按钮,这类型的按钮往往只利用几何色块的变化,就能抓住使用者的眼光,并且从几何形状中明白按钮的含意,这也是Material Design非常强调的设计理念和精髓。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!