• flask实战-个人博客-视图函数


    视图函数

    在上面我们创建了所有必须的模型类、模板文件和表单类。经过程序规划和设计后,我们可以创建大部分视图函数。这些视图函数暂时没有实现具体功能,仅渲染对应的模板,或是重定向到其他视图。以blog蓝本为例,如下所示:

    personalBlog/blueprints/blog.py: 创建视图函数

    #encoding=utf-8
    
    from flask import render_template, Blueprint
    
    blog_bp = Blueint('blog', __name__)
    
    @blog_bp.route('/')
    def index():
        return render_template('blog/index.html')
    
    @blog_bp.route('/about')
    def about():
        return render_template('blog/about.html')
    
    @blog_bp.route('/category/<int:category_id>')
    def show_category(category_id):
        return render_template('blog/category.html')
    
    @blog_bp.route('/post/<int:post_id>', methods = ['GET', 'POST'])
    def show_post(post_id):
        return render_template('blog/post.html')

    和blog蓝本类似,我们在blueprints子包中创建了auth.py、admin.py脚本,这些脚本中分别创建了auth和admin蓝本,蓝本实例的名称分别为auth_bp和admin_bp。

    除了视图函数外,我们还要添加一些基本的组件,比如自定义命令、错误处理函数(包含404、500以及新添加的400错误处理函数)、使用函数(包含redirect_back()和is_safe_url())等。

    personalBlog/forms.py: 增加SettingForm()表单

    class SettingForm(FlaskForm):
        name = StringField('Name', validators = [DataRequired(), Length(1, 70)])
        blog_title = StringField('Blog Title', validators = [DataRequired(), Length(1, 60)])
        blog_sub_title = StringField('Blog Sub Title', validators = [DataRequired(), Length(1, 100)])
        about = CKEditorField('About Page', validators = [DataRequired()])
        submit = SubmitField()
  • 相关阅读:
    jquery
    实现元素垂直居中
    浏览器 标准模式和怪异模式
    cookie session ajax
    React props.children
    使用React.lazy报错Import in body of module; reorder to top import/first
    state 和 props 之间的区别
    Harbor打怪升级
    Centos7下安装yum工具
    正则表达式匹配两个特殊字符中间的内容(特殊字符不显示)
  • 原文地址:https://www.cnblogs.com/xiaxiaoxu/p/10841519.html
Copyright © 2020-2023  润新知