flask day03

关于 git从本地上传到github

git init

将所有文件添加到仓库
git add

把所有文件提交到仓库,双引号是提交的注释内容
git commit -m "提交文件"

git remote add origin地址关联远程仓库(只需要关联一次)

//如果创建远程仓库的时候仓库中有默认文
git pull --rebase origin master

git push [-u]origin master - 提交(-u在第一次提交分之的时候才用)

蓝图 /blueprint

产生背景:管理路由地址

安装:pip install flask-blueprint

使用:

# 1.定义一个蓝图'first'
blue = Blueprint('first',__name__)
# 写路由'index'
@blue.route('/index/')
# 2.管理蓝图
app.register_blueprint(blueprint=blue)

# 3.跳转 

# ① 有参跳转: redirect即重定向
# redirect(url_for('生成蓝图的第一个参数.跳转的函数名称', 参数名=值, 参数名2=值2))
def stu():
   stu_scores = [90, 89, 92, 88]
   content = '<h2>你真棒!</h2>'
   return render_template('stu.html',scores = stu_scores,content_h2 = content )

# ② 无参跳转:
# redirect(url_for('生成蓝图的第一个参数.跳转的函数名称'))
return redirect(url_for('first.s_id')

注:下图代码在浏览器中访问/redirect_func/时会跳转至/s_id/1

@blue.route('/redirect_func/')
def redirect_func():
    # return redirect('/login/')
    # return redirect(url_for('first.login'))
    # return redirect('/s_id/1/')
    return redirect(url_for('first.s_id', id=1))

@blue.route('/s_id/<int:id>/')
def s_id(id):
    return 's_id %s' % id

装饰器 / decorator

①外层函数嵌套内层函数
②内层函数调用外层参数
③外层函数返回内层函数

def is_login(func):
    @wraps(func)
    # 加一个装饰器令使用装饰器的函数最后返回的函数是本身而不是装饰器
    def check():
        # 登陆过后就能访问index.html界面
        try:
            session['login_status']
            return func()
        except:
            # 没有登陆不让访问,跳转到session_login.html
            return render_template('session_login.html')
    return check

模板

Ⅰ.父模板
①定义网站模板的大体框架,定义可以被动态填充内容的block块
②block块定义: {% block name %} {% endblock %}
注意:block名称不能取同名
Ⅱ.子模板
①继承父模板: {% extends '父模板' %}
②动态可选择性的填充父模板中定义的block块, 使用{% block name %} 动态内容 {% endblock %}

解析标签:

{% 标签名 %} {% end标签名 %}
① for: {% for a in [] %} {% else %} {% endfor %}
② if: {% if 判断条件 %} {% else %} {% endif %}
③ block: {% block name %} {% endblock %}

解析变量:

{{ 变量名 }}
loop.index: 从1开始的值
loop.index0: 从0开始
loop.revindex: 倒序到1结束
loop.revindex0: 倒序到0结束
loop.first: 第一次循环返回True
loop.last: 最后一次循环返回True

注解: {# 注解内容 #}
过滤器

写法: {{ 变量 | 过滤器 }}
safe、lenth、upper

父模板 base.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
     <!-- jinja2 -->
    <title>
        {% block title %}
        {% endblock %}
    </title>
    {% block css %}
    {% endblock %}
    {% block js %}
    {% endblock %}
</head>
<body>
    {% block content %}
    {% endblock %}
</body>
</html>

子模板

{% extends 'base_main.html' %}

{% block title %}
    学生列表页面
{% endblock %}
{% block css %}
    <!--引入一-->
    <!--<link rel="stylesheet" href="/static/css/style.css">-->
    <!--第二种写法-->
    <link rel="stylesheet" href="{{ url_for('static',filename='css/style.css') }}">
{% endblock %}
{% block js %}
    <!--<script src="1213.js"></script>-->
{% endblock %}

{% block content %}
<!-- 将样式加载出来 -->
<p> {{ content_h2 | safe }}</p>
<p> {{ 'python' | length }}</p>
<!-- 都会执行但是只能显示最后的效果 -->
<p> {{ 'python' | length | upper }}</p>
<p> {{ 'python' | lower }}</p>
<p> {{ content_h2 | striptags }}</p>

<p> {{ scores }} </p>
<!-- 解析标签 extends, block, for -->
<ul>
    {% for a in scores %}
    {{ loop.revindex0 }}
    {{ loop.first }}
    {{ loop.last }}
           <li {% if loop.index == 1 %} style="color: yellow" {% endif %}>{{ a }}</li>
    {% else %}
            <li>没有学生成绩数据</li>
    {% endfor %}

</ul>
<table>
     <thead>
        <th class="name">姓名</th>
        <th>年龄</th>
    </thead>
    <tbody>
        <tr>
            <td>张三</td>
            <td>28</td>
        </tr>
        <tr>
            <td>李四</td>
            <td>29</td>
        </tr>
    </tbody>
</table>
{% endblock %}

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>学生列表页面</title>
</head>
<body>

</body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • Git常用语法 [TOC] Git简介 描述 ​ Git(读音为/gɪt/。)是一个开源的分布式版本控制系统,...
    君惜丶阅读 3,494评论 0 13
  • 1. 安装 Github 查看是否安装git: $ git config --global user.name "...
    Albert_Sun阅读 13,630评论 9 163
  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,456评论 1 26
  • 1.git的安装 1.1 在Windows上安装Git msysgit是Windows版的Git,从https:/...
    落魂灬阅读 12,648评论 4 54
  • 突如其来 一晚 梦见你 叫我心惊肉跳 像是终于推到山顶的巨石又 滚到了山脚 ——《名叫遗忘的石头》 ​​​​
    段童阅读 146评论 0 2