专栏首页python3python 宏使用详解

python 宏使用详解

什么是宏?

宏类似python中的函数,可以传参数进去,但不能有返回值!在实际开发项目中,可以将一些复用代码抽取出来放到宏中,然后把不固定的值作为变量!

宏的使用!

在讲宏使用之前,我们先网上找一张表单注册的图片,图片如下:

然后我们通过模板渲染的方式来实现这个表单!

新建一个test.py文件,代码如下(相信很多朋友都记得滚瓜烂熟了!):

from flask import Flask,render_template

app = Flask(__name__)

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

if __name__ == "__main__":
    app.run(debug=True)

再在templates文件下新建一个test.html文件,代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>用户注册</title>
</head>
<body>
      <form action="#" method="post">
          <table>
              <tr>
                  <td>用户名</td>
                  <td><input type="text" name="name" value=""></td>
              </tr>
              <tr>
                  <td>密码</td>
                  <td><input type="password" name="password1" value=""></td>
              </tr>
              <tr>
                  <td>确认密码</td>
                  <td><input type="password" name="password2" value=""></td>
              </tr>
              <tr>
                  <td>E-Mail:</td>
                  <td><input type="text" name="email" value=""></td>
              </tr>
              <tr>
                  <td>手机号码</td>
                  <td><input type="text" name="m-phone" value=""></td>
              </tr>
              <tr>
                  <td>固定电话</td>
                  <td><input type="text" name="tel" value=""></td>
              </tr>
              <tr>
                  <td>家庭住址</td>
                  <td><input type="text" name="address" value=""></td>
              </tr>
              <tr>
                  <td><input type="submit" name="name" value="注册"></td>
                    <td><input type="submit" name="name" value="登录"></td>
              </tr>
          </table>
      </form>
</body>
</html>

运行test.py文件,结果如下:

相信对很多朋友来说,实现这个表单并不是什么难事!

上述代码虽然实现了表单注册这个界面!但是代码太复杂了,每次都得去input一下,太麻烦了!!是吧??

下面我们就用宏来实现这个效果!

首先,我们分析test.html文件表单的共性,是不是都有一个input标签啊!是不是??

OK,下面我们就把这段代码抽取出来放到宏中,代码如下:

{#{% macro %}{% endmarco %}定义宏的标准语法,起始跟结束标签 #} 
{#macro后面的input为宏的名字,括号中的值为宏的参数,例如:type="text"表示默认文本类型为text #}
{% macro input(name,type="text",value="") %}
{#将input宏后面的name,type,value参数作为变量传入name,type,value值中 #}
   <input name="{{ name }}" type="{{ type }}" value="{{ value }}">
{% endmacro %}

宏定义好了,我们在test.html文件中把之前写的form表单代码删除掉。再输入下方代码:

<form action="#">
            <table>
                 <tr>
                <td>姓名:</td>
                <td>{{ input("username") }}</td>
            </tr>
            <tr>
                <td>密码:</td>
                <td>{{ input("password1",type="password") }}</td>
            </tr>
            <tr>
                <td>确认密码:</td>
                <td>{{ input("password2",type="password") }}</td>
            </tr>
            <tr>
                <td>E-Mail:</td>
                <td>{{ input("email") }}</td>
            </tr>
            <tr>
                <td>手机号码:</td>
                <td>{{ input("phone") }}</td>
            </tr>
            <tr>
                <td>固定电话:</td>
                <td>{{ input("tel") }}</td>
            </tr>
            <tr>
                <td>地址:</td>
                <td>{{ input("address") }}</td>
            </tr>
            <tr>
                <td>{{ input("zuce",type="submit",value="注册") }}</td>
                <td>{{ input("denglu",type="submit",value="登录") }}</td>
            </tr>
            </table>
        </form>

代码是不是比之前简洁多了,看着也舒服。

说了那么多,还不知道运行结果咋样,我们运行试试!结果如下:

在实际开发项目中,宏用的地方还是挺多的,希望朋友们能够学会它,只有学会它,我们在开发项目中才能得心应手!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Django 项目中添加静态文件夹

    在 mysite 文件夹下添加一个 statics 文件夹用来存放 js 文件

    py3study
  • python_day12_html

    内联标签:<a><input><img><sub><sup><textarea><span>

    py3study
  • Python爬取代理IP

    py3study
  • Mybatis案例超详解(上)

    本来是想像之前一样继续跟新Mybatis,但由于种种原因,迟迟没有更新,快开学了,学了一个暑假,博客也更新了不少,我觉得我得缓缓,先整合一些案例练练,等我再成...

    泰斗贤若如
  • HTML代码片段

    Joel
  • html基础+常用标签

    程序员同行者
  • bootstrap表格

    条纹表格.table-striped(作用在table的class类名),实现隔行换色

    十月梦想
  • Dom 事件处理函数

    别人整理的,我顺手就给捏来了哈哈。很详细的一些事件,浏览器支持情况,以及详细的说明。在这里向整理者致敬。 <!DOCTYPE html PUBLIC "-//W...

    练小习
  • JQ实现计算器功能

    下面是计算器的实现方法,主要是使用了JQ,设计原型依据小米手机计算器,实现了基础的单步骤运算,做了简单的校验判断,实现了加减乘除取余等功能;

    申霖
  • html学习笔记(一)

    单标签 <! Doctype html> 双标签 <html> </html> <head></head> <title></title>

    Daotin

扫码关注云+社区

领取腾讯云代金券