[心得]基于Flask技术的web博客开发总结
来源:互联网 发布:xcc mixer软件 编辑:程序博客网 时间:2024/05/19 16:03
Flask主要依赖werkzeng和jinja2模板。
werkzeng提供route,debug和web服务,jinja2模板提供网页前端展示功能。
bootstrap是twitter的一个开源框架,它提供的用户界面的组件可以方便地在flask中复用。
表现层状态转移(Representational State Transfer,REST)架构
资源是 REST 架构方式的核心概念。在 REST 架构中,资源是程序中你要着重关注的事物。
开发完一个项目之后,可以用
pip freeze > requirements.txt
来把开发中调用的依赖库dump到一个文件。
当部署时,
pip install -r requirements.txt
就能一下子把所依赖的库装好。
这个博客具备了用户认证,表单校验,用户权限数据库管理,关注关系设定,博客发布,个人主页等功能。
对于每一个功能,首先是从main/views.py下查找对应的路由,然后经过表单验证之后,跳转相应的页面。
这是蓝图blueprint,蓝图的作用是简化路由:
from flask import Blueprintmain = Blueprint('main', __name__)from . import views, errors
为了使用蓝图,需要采用工厂模式来推迟实例化app:
def create_app(config_name='default'): app = Flask(__name__) app.config.from_object(config[config_name]) config[config_name].init_app(app) bootstrap.init_app(app) mail.init_app(app) moment.init_app(app) db.init_app(app) login_manager.init_app(app) pagedown.init_app(app) from .main import main as main_blueprint app.register_blueprint(main_blueprint) from .auth import auth as auth_blueprint app.register_blueprint(auth_blueprint, url_prefix='/auth') from .api_1_0 import api as api_1_0_blueprint app.register_blueprint(api_1_0_blueprint, url_prefix='/api/v1.0') return app
这是路由例子:
@main.route('/user/<username>')def user(username): user = User.query.filter_by(username).first() if user is None: abort(404) posts = user.posts.order_by(Post.timestamp.desc()).all() return render_template('user.html', user=user, posts=posts)
每一个页面经过jinja2模板的复用之后,可以提高前端编辑效率
{% extends "base.html" %}{% import "bootstrap/wtf.html" as wtf %}{% import "_macros.html" as macros %}{% block title %}topcoder - Post{% endblock %}{% block page_content %}{% include '_posts.html' %}<h4 id="comments">Comments</h4>{% if current_user.can(Permission.COMMENT) %}<div class="comment-form"> {{ wtf.quick_form(form) }}</div>{% endif %}{% include '_comments.html' %}{% if pagination %}<div class="pagination"> {{ macros.pagination_widget(pagination, '.post', fragment='#comments', id=posts[0].id) }}</div>{% endif %}{% endblock %}
总的来说,Flask核心很轻量,开发的功能主要是拿已有的一些模块组装在一起。
附录:MD编辑快捷操作备忘
快捷键
- 加粗
Ctrl + B
- 斜体
Ctrl + I
- 引用
Ctrl + Q
- 插入链接
Ctrl + L
- 插入代码
Ctrl + K
- 插入图片
Ctrl + G
- 提升标题
Ctrl + H
- 有序列表
Ctrl + O
- 无序列表
Ctrl + U
- 横线
Ctrl + R
- 撤销
Ctrl + Z
- 重做
Ctrl + Y
可以使用冒号来定义对齐方式:
定义列表
- Markdown Extra 定义列表语法:
- 项目1
- 项目2
- 定义 A
- 定义 B
- 项目3
- 定义 C
- 定义 D
定义D内容
代码块
代码块语法遵循标准markdown代码,例如: python
通过本编辑器离线写博客(直接在曾经使用过的浏览器中输入write.blog.csdn.net/mdeditor即可。Markdown编辑器使用浏览器离线存储将内容保存在本地。
0 0
- [心得]基于Flask技术的web博客开发总结
- Flask Web 开发 博客文章
- Flask Web开发(一)基于python的Web表单
- Flask之旅《Flask Web开发:基于Python的Web应用开发实战》学习笔记
- 第一部分 flask简介《Flask Web开发:基于Python的Web应用开发实战》
- 基于Python的Flask Web 开发 笔记 (1)
- 基于Python的Flask Web开发 笔记 (2)
- Flask Web 开发 博客文章_2
- Flask Web 开发 博客文章_3
- Flask Web 开发 博客文章_4
- Flask Web 开发 博客文章_5
- Flask RESTful Web服务的开发套路总结
- Flask WEB 开发(基于Python的Web应用开发实践)遇到的bug
- 基于Flask的博客系统搭建
- 基于flask实现的简单博客
- Flask Web开发:基于Python的Web应用开发实战pdf
- 写技术博客的心得.
- gae 部署基于flask的web服务器
- shell脚本之seq命令
- RESTful风格(使用Ajax+Spring MVC框架实现)
- Activity生命周期和启动模式
- 【poj1151】【离散化】Atlantis
- Android ListView、GridView中getChildAt返回值不正确的问题
- [心得]基于Flask技术的web博客开发总结
- wget 命令用法详解
- js 读取input[type=file]
- Android OpenGLES2.0(七)——着色器语言GLSL
- 菜鸟们掌握这些,自增自减再也不用混淆啦!
- Javascript:通用不间断滚动&省、市、地区联动选择JS封装类
- Android apk应用包名获取工具,以及源码
- 用docker快速搭建l2tp VPN服务器
- 带*类型的特征