前端只处理前端本身的逻辑,比如图形展示、文字的格式化等,后端也只处理后端自己的业务代码,前端和后盾通过某种机制来耦合。
我们通过 M-V-C 的概念来说明前后端分离的概念。M 指的是 Model-数据模型,V 指的是 View-视图,C 指的是 Controller-控制器。视图可以理解为前端,主要用于对数据的呈现,模型可以理解为后端,主要负责对业务的处理,而控制器主要负责接收用户的输入并协调视图和模型。M、V、C 三者之间的关系如下:
Python 代码的模拟实现如下:
class ProductInfo:
def __init__(self):
self.product_name = None
self.id = None
self.price = None
self.manufacturer = None
class ProductView:
def print_product(self):
product = ProductInfo() # 耦合点
print(f"Name: {product.product_name}")
print(f"Price: {product.price}")
print(f"Manufacturer: {product.manufacturer}")
- 类 ProductView 表示前端的功能,使用一些 print 语句来打印产品的信息,而类 ProductInfo 代表产品记录。如果不采用前后端分离的方式,那么可以在 ProductView 中直接调用后端的数据,产生耦合点。
然后,通过 MVC 的方法增加控制器并解耦,具体实现如下:
class ProductInfo:
def __init__(self):
self.product_name = None
self.id = None
self.price = None
self.manufacturer = None
class ProductView:
"""
Product 的展示
"""
def print_product(self, product):
print(f"Name: {product.product_name}")
print(f"Price: {product.price}")
print(f"Manufacturer: {product.manufacturer}")
class ProductController:
"""
控制器,控制用户的输入,选择合适的 view 输出
"""
def __init__(self, product, view):
self.product = product
self.product_view = view
def refresh_view(self):
self.product_view.print_product(self.product)
def update_model(self, product_name, price, manufacturer):
self.product.product_name = product_name
self.product.price = price
self.product.manufacturer = manufacturer
# 实际执行代码
if __name__ == '__main__':
controller = ProductController(ProductInfo(), ProductView())
controller.refresh_view()
controller.update_model("new name", 15, "ABC Inc")
controller.product_view.print_product(controller.product)
- 上述代码中,我们通过引入 ProductController 类分离了视图和模型,使得视图和模型的耦合关系松开,通过控制器决定 View 的更新和模型的更新,而不是视图直接调用模型或者模型去驱动视图。今后如果需要视图上的逻辑(比如想换一个视图)就可以轻松地完成。