关注点分离(Separation of Concerns, SoC)原则是软件工程相关的设计原则之一。 SoC原则背后的思想是将一个应用切分成不同的部分,每个部分解决一个单独的关注点。分层设计中的层次(数据访问层、业务逻辑层和表示层等)即是关注点的例子。使用SoC原则能简化软件应用的开发和维护
模型—视图—控制器(Model-View-Controller, MVC)模式是应用到面向对象编程的Soc原则。模式的名称来自用来切分软件应用的三个主要部分,即模型部分、视图部分和控制器部分。 MVC被认为是一种架构模式而不是一种设计模式。架构模式与设计模式之间的区别在于前者比后者的范畴更广。然而, MVC太重要了,不能仅因为这个原因就跳过不说。即使我们从不需要从头实现它,也需要熟悉它,因为所有常见框架都使用了MVC或者是其略微不同的版本(之后会详述)。模型是核心的部分,代表着应用的信息本源,包含和管理(业务)逻辑、数据、状态以及应用的规则。视图是模型的可视化表现。视图的例子有,计算机图形用户界面、计算机终端的文本输出、智能手机的应用图形界面、 PDF文档、饼图和柱状图等。视图只是展示数据,并不处理数据。控制器是模型与视图之间的链接/粘附。模型与视图之间的所有通信都通过控制器进行.
对于将初始屏幕渲染给用户之后使用MVC的应用,其典型使用方式如下所示。
用户通过单击(键入、触摸等)某个按钮触发一个视图
视图把用户操作告知控制器
控制器处理用户输入,并与模型交互
模型执行所有必要的校验和状态改变,并通知控制器应该做什么
控制器按照模型给出的指令,指导视图适当地更新和显示输出
你可能想知道为什么控制器部分是必要的?我们能跳过它吗?能,但那样我们将失去MVC提供的一大优势:无需修改模型就能使用多个视图的能力(甚至可以根据需要同时使用多个视图)。为了实现模型与其表现之间的解耦,每个视图通常都需要属于它的控制器。如果模型直接与特定视图通信,我们将无法对同一个模型使用多个视图(或者至少无法以简洁模块化的方式实现)。
直接上实例,详细的说明code中都有说明:# 设计模式(模型-视图-控制器)
# Base on python3.6.5实现
# 这是一个简单的点餐系统,指在说明通过python对此设计模式的实现:Cutomer_OrderView相当于顾客,顾客可以点单;
# Kitchen_OrderModel相当于厨房,负责食品的制作;Waiter_OrderControler相当于服务员,负责接受客户的下单,并将下单结果交给厨房制作.
#!/user/bin/env python3
#-*- coding:utf-8 -*-
# 设计模式(模型-视图-控制器)
# Base on python3.6.5实现
# 这是一个简单的点餐系统,指在说明通过python对此设计模式的实现:Cutomer_OrderView相当于顾客,顾客可以点单;
# Kitchen_OrderModel相当于厨房,负责食品的制作;Waiter_OrderControler相当于服务员,负责接受客户的下单,并将下单结果交给厨房制作.
from time import sleep
orderList = ('糖醋排骨', '清蒸鲈鱼', '蚂蚁上树', '拍黄瓜', '油淋茄子', '爆炒鱿鱼')
# 完好的模型要满足以下要求:
# 包含所有的校验/业务规则/逻辑
# 处理应用的状态
# 访问应用数据(数据库、云或其他)
# 不依赖UI
class Kitchen_OrderModel:
def makeFood(self, n):
if n.isdigit():
if int(n) <= len(orderList):
n = int(n) - 1
print(f'你所点的菜品:{orderList[n]}正在制作中... ...')
sleep(1)
value = f'你所点的菜品:{orderList[n]}已经制作好了,请享用.\n\n'
return value
else:
value = '点菜超出菜单范围,请重新点菜.\n'
else:
value = '点菜超出菜单范围,请重新点菜.\n'
return value
# 完好的视图要满足以下要求:
# 展示数据
# 允许用户与其交互
# 仅做最小的数据处理,通常由一种模板语言提供处理能力(例如,使用简单的变量和循环控制)
# 不存储任何数据
# 不直接访问应用数据
# 不包含校验/业务规则/逻辑
class Cutomer_OrderView:
def showResult(self, food):
print(f'{food}\n\n')
def selectFood(self):
select = input('请点餐(1~6):')
return select
# 完好的控制器要满足以下要求:
# 在用户与视图交互时,更新模型
# 在模型改变时,更新视图
# 如果需要,在数据传递给模型/视图之前进行处理
# 不展示数据
# 不直接访问应用数据
# 不包含校验/业务规则/逻辑
class Waiter_OrderControler:
def __init__(self):
self.model = Kitchen_OrderModel()
self.view = Cutomer_OrderView()
def run(self):
valid_input = False
while not valid_input:
selString = self.view.selectFood().strip().lower()
valid_input = True
food = self.model.makeFood(selString)
self.view.showResult(food)
if __name__ == '__main__':
customer = Waiter_OrderControler()
while True:
for i in orderList:
print(f'{orderList.index(i)+1}: {i}')
customer.run()