Flask项目入门和视图

1、第一个项目的结构

以示例代码中的入口文件app.py为例子

(1)引入Flask以及创建Flask对象

python 复制代码
from flask import Flask
app = Flask(__name__)

(2) 路由route + 视图函数

python 复制代码
@app.route('/index/')
def hello_world():
    # 响应:返回给浏览器的数据
    return 'Hello World!'

在上面代码中'index'是路由,hello_world就是视图函数,路由就是访问的一个路径,视图函数里面可以引入模版返回页面或者返回数据。上面服务启动之后在浏览器中访问http://127.0.0.1:5000/index/,浏览器就输出了试图函数的内容"hello World"。上述流程可以总结为以下 Flask整体框架的流程图

首先我们来结合这个图讲一下项目的整体流程,首先是浏览器或者前端访问进来,访问时通过路由进来的,路由进来后在视图函数中做出相应的返回,视图函数可以返回一个模版(比如htlm页面)给前端或者也可以返回一些通过模型数据库查询出来的数据(比如接口里的json数据)

(3)启动参数

python 复制代码
if __name__ == '__main__':
    # 启动
    app.run(debug=True)

下面是一些启动参数的含义

python 复制代码
app.run(debug=True, port=5000, host='0.0.0.0')

1、 debug 是否开启调试模式,开启后修改过python代码会自动重启

2、port 启动指定服务器的端口号,默认是5000

3、host 主机,默认是127.0.0.1,指定为0.0.0.0代表本机所有ip

2、模版渲染

上面说了浏览器访问进来之后通过路由、视图函数可以通过模版渲染返回一个页面给浏览器,具体怎么弄,往下看:

(1)引入 render_template

python 复制代码
from flask import Flask, render_template, jsonify
app = Flask(__name__)
#首先引入render_template

@app.route('/index/')
def index():

    # 返回字符串: 支持HTML标签
    # return '<b>Flask Index</b>'

    # 模板渲染
    return render_template('index.html', name='法外狂徒张三')

上面代码中,首先import render_template,然后在试图函数中就可以通过模版渲染的方式返回一个页面给浏览器,比如 return render_template('index.html', name='法外狂徒张三'),这个代码就是通过模版渲染的方式把index页面返回给浏览器,当输入http://服务ip或者域名/index/的时候就展示了index.html的页面.

(2)模版目录结构

那这个index页面放在什么地方呢,看下图:

文件夹templates和static两个文件夹分别放了页面和css文件,代码分别如下

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

<!-- 3种导入静态文件的方式  -->
<!--    <link rel="stylesheet" href="../static/index.css">-->
<!--    <link rel="stylesheet" href="/static/index.css">-->
    <link rel="stylesheet" href="{{ url_for('static', filename='index.css') }}">

</head>
<body>
    <h2>Index</h2>
    <hr>

    <h4>name: {{ name }}</h4>

</body>
</html>
css 复制代码
h4 {
    color: red;
}

html文件中可以通过示例代码的方式引入css文件内容

3、返回json数据

上面演示了通过模版渲染返回页面,下面看看通过json系列化返回json数据

(1)首先还是引入jsonify

python 复制代码
from flask import Flask, render_template, jsonify

(2)在视图函数中返回json数据

python 复制代码
from flask import Flask, render_template, jsonify
app = Flask(__name__)
#首先引入jsonify

@app.route('/index/')
def index():

   # JSON
   # jsonify: 序列化
   return jsonify({'name': '张三', 'age': 33})
相关推荐
Dfreedom.13 小时前
从 model(x) 到__call__:解密深度学习框架的设计基石
人工智能·pytorch·python·深度学习·call
weixin_4250230013 小时前
Spring Boot 配置文件优先级详解
spring boot·后端·python
weixin_4250230013 小时前
Spring Boot 实用核心技巧汇总:日期格式化、线程管控、MCP服务、AOP进阶等
java·spring boot·后端
一线大码14 小时前
Java 8-25 各个版本新特性总结
java·后端
VX:Fegn089514 小时前
计算机毕业设计|基于springboot + vue校园社团管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
To Be Clean Coder14 小时前
【Spring源码】通过 Bean 工厂获取 Bean 的过程
java·后端·spring
小徐Chao努力15 小时前
【Langchain4j-Java AI开发】06-工具与函数调用
java·人工智能·python
无心水15 小时前
【神经风格迁移:全链路压测】33、全链路监控与性能优化最佳实践:Java+Python+AI系统稳定性保障的终极武器
java·python·性能优化
luoluoal15 小时前
基于python的小区监控图像拼接系统(源码+文档)
python·mysql·django·毕业设计·源码
weixin1997010801615 小时前
闲鱼 item_get - 商品详情接口对接全攻略:从入门到精通
java·后端·spring