Flask-宏和import语句


模板中的宏跟python中的函数类似,可以传递参数,但是不能有返回值,可以将一些经常用到的代码片段放到宏中,然后把一些不固定的值抽取出来当成一个变量

import语句
在真实的开发中,会将一些常用的宏单独放在一个文件中,在需要使用的时候,再从这个文件中进行导入。import语句的用法跟python中的import类似,可以直接import…as…,也可以from…import…或者from…import…as…,假设现在有一个文件,叫做forms.html,里面有两个宏分别为input和textarea

另外需要注意的是,导入模板并不会把当前上下文中的变量添加到被导入的模板中,如果你想要导入一个需要访问当前上下文变量的宏,有两种可能的方法
• 显式地传入请求或请求对象的属性作为宏的参数
• 与上下文一起(with context)导入宏
与上下文中一起(with context)导入的方式

@app.route("/macro/")
def macro():
    return render_template("macro.html")

通过自定义-“宏”-input标签只写了一次-通过传参的方式来完成需求 - 快速创建input标签

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    {% macro input(name,value='', type='text') %}
        <input type="{{ type }}", name="{{ name }}", value="{{ value }}">
    {% endmacro %}

     <table>
         <tr>
             <td>用户名:</td>
             <td>{{ input('username') }}</td>
         </tr>
          <tr>
             <td>密码:</td>
             <td>{{ input('password',type='password') }}</td>
         </tr>
          <tr>
             <td>密码:</td>
             <td>{{ input(value='提交',type='submit')}}</td>
         </tr>
     </table>
</body>
</html>

import …as
导入宏:
在这里插入图片描述
两种导入方式:
在这里插入图片描述
with context - 给模版传参
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask-MySQL 是一个 Flask 扩展,提供了在 Flask 应用中使用 MySQL 数据库的功能。它简化了与 MySQL 数据库的交互,提供了一些常用的数据库操作方法,如查询、插入、更新和删除数据等。 下面是 Flask-MySQL 的基本使用方法: 1. 安装 Flask-MySQL 扩展 ``` pip install flask-mysql ``` 2. 在 Flask 应用中配置 MySQL 数据库连接参数 ```python from flask import Flask from flaskext.mysql import MySQL app = Flask(__name__) mysql = MySQL() # MySQL 配置 app.config['MYSQL_DATABASE_USER'] = 'username' # 数据库用户名 app.config['MYSQL_DATABASE_PASSWORD'] = 'password' # 数据库密码 app.config['MYSQL_DATABASE_DB'] = 'database_name' # 数据库名称 app.config['MYSQL_DATABASE_HOST'] = 'localhost' # 数据库主机地址 mysql.init_app(app) ``` 3. 在 Flask 视图函数中使用 MySQL 进行数据库操作 ```python from flask import Flask, render_template from flaskext.mysql import MySQL app = Flask(__name__) mysql = MySQL() # MySQL 配置 app.config['MYSQL_DATABASE_USER'] = 'username' # 数据库用户名 app.config['MYSQL_DATABASE_PASSWORD'] = 'password' # 数据库密码 app.config['MYSQL_DATABASE_DB'] = 'database_name' # 数据库名称 app.config['MYSQL_DATABASE_HOST'] = 'localhost' # 数据库主机地址 mysql.init_app(app) @app.route('/') def index(): cursor = mysql.get_db().cursor() cursor.execute('SELECT * FROM users') users = cursor.fetchall() return render_template('index.html', users=users) ``` 在上面的代码中,我们首先从 Flask 扩展中导入 MySQL 类,并创建一个 MySQL 实例。然后,在 Flask 应用中配置 MySQL 数据库连接参数,并使用 `mysql.init_app(app)` 初始化 MySQL 实例。 在 Flask 视图函数中,我们通过 `mysql.get_db()` 获取到数据库连接对象,然后可以使用 `cursor()` 方法创建一个游标对象,通过游标对象执行 SQL 查询语句,最后使用 `fetchall()` 方法获取查询结果。 注意:在实际应用中,我们还需要处理数据库连接异常、数据转换等问题,这里只是简单介绍 Flask-MySQL 的基本用法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值