Python3教程Web开发实战梳理-day7(编写MVC)

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

猜你喜欢

转载自blog.csdn.net/josephpai/article/details/76037662
今日推荐