Day7:编写MVC
通过前面几天的的努力,ORM框架、Web框架和配置都已就绪,我们可以开始编写一个最简单的MVC,把它们全部启动起来。
MVC:Model-View-Controller,中文名“模型-视图-控制器”。
其中Python处理的URL函数就是C:Controller,Controller主要负责业务逻辑,比如检查用户名是否存在,取出用户信息等等;
而View负责显示逻辑,通过一些简单的替换变量,View生成最终用户看到的HTML,那View实质就是HTML模板(如Django等),而在本次Web开发就是Jinja2模板;
Model是用来传给View的,这样View在替换变量的时候,就可以从Model中取出相应的数据。
通过Web框架的@get和ORM框架的Model支持,可以很容易地编写一个处理首页URL的函数
新建handlers.py:
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
' url handlers '
import re, time, json, logging, hashlib, base64, asyncio
from coroweb import get, post
from models import User, Comment, Blog, next_id
@get('/')
async def index(request):
users = await User.findAll()
return {
'__template__': 'test.html',
'users': users
}
‘_template_’指定的模板文件是test.html,其他参数是传递给模板的数据,所以我们在模板的根目录templates下创建test.html:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>Test users - Awesome Python Webapp</title>
</head>
<body>
<h1>All users</h1>
{% for u in users %}
<p>{{ u.name }} / {{ u.email }}</p>
{% endfor %}
</body>
</html>
这个html中逻辑部分用花括号{和百分号%来嵌套,这是jinja2模板的规范
和前段时间学习的Java中的JSP有些相似
接下来,运行app.py启动服务器,在浏览器访问
localhost:9000/
应该可以看到你的数据库表中users中存储的数据,如果没有的话可以自己手动添加几天记录再试一下。
这就是一个简单的MVC