flask-web页面分页和上传图片

效果图

编辑页面
flask00.png

一、分页

  • paginate(self, page=None, per_page=None, error_out=True, max_per_page=None)
    一般就传前两个参数就行
@blue.route('/all_stu/')
def all_stu():
    if request.method == 'GET':
        # 从url中获取page参数
        page = int(request.args.get('page', 1))
        pg = Student.query.paginate(page, 5)
        # 获取当页参数
        stus = pg.items
        return render_template('stus.html', stus=stus, pg=pg)

然后将pg和stus传入html模板文件解析即可

<table>
        <thead>
            <th>编号</th>
            <th>姓名</th>
            <th>年龄</th>
        </thead>

        <tbody>
        {% for stu in stus %}
        <tr>
            <td>{{ loop.index}}</td>
            <td>{{ stu.s_name}}</td>
            <td>{{ stu.s_age }}</td>
        </tr>

        {% endfor %}
        </tbody>

</table>
    <p>当前第{{ pg.page }}页,共{{ pg.pages }}页</p>
    {% if pg.has_prev %}
    <a href="{{ url_for('app.all_stu')}}?page={{ pg.prev_num}}">上一页</a>
    {% endif %}

    {% for i in pg.iter_pages() %}
        {% if i %}
        <a href="{{ url_for('app.all_stu')}}?page={{i}}">{{i}}</a>
        {% else %}
            ...
        {% endif %}
    {% endfor %}

    {% if pg.has_next %}
    <a href="{{ url_for('app.all_stu')}}?page={{ pg.next_num}}">下一页</a>
    {% endif %}

二、关联模型

  • 一对多
    在一个表中定义一个外键(多的一方)
    db.ForeignKey('关联表名.id') 例如:
g_id = db.Column(db.Integer, db.ForeignKey('grade.id'), nullable=True)

另一个表定义一个关联字段(为一的一方)
关联字段db.relatonship('关联的模型名',backref='反向引用参数') 例如:

# 定义了一个关联关系字段,和反向引用backref参数
s_g = db.relationship('Student', backref='g')
  • 多对多
    定义外键字段是通过中间表,db.Table(表名,子段)
    关联字段db.relationship('关联的模型名',secondary='中间表',backref='反向引用参数')
    relationship定义的字段,可以放在任意一个模型中
s_c = db.Table('s_c',
               db.Column('s_id', db.Integer, db.ForeignKey('student.id')),
               db.Column('c_id', db.Integer, db.ForeignKey('course.id'))
               )

class Course(db.Model):
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    c_name = db.Column(db.String(10), unique=True, nullable=False)
    stu = db.relationship('Student', secondary=s_c, backref='cou')

上传图片

  • 视图函数
@blue.route('/edit_stu/<int:id>/', methods=['GET','POST'])
def edit_stu(id):
    if request.method == 'GET':
        stus = Student.query.get(id)
        return render_template('edit.html',stus=stus)
    if request.method == 'POST':
        # 接受图片,并保存图片
        icon = request.files.get('image')
        # 获取项目的根路径
        BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
        # 获取媒体文件的路径
        STATIC_DIR = os.path.join(BASE_DIR, 'static')
        MEDIA_DIR = os.path.join(STATIC_DIR, 'media')
        # 随机生成图片名称
        filename = str(uuid.uuid4())
        a = icon.mimetype.split('/')[-1:][0]
        name = filename + '.' + a
        print(name)
        # 拼接图片地址
        path = os.path.join(MEDIA_DIR, name)
        # 保存
        icon.save(path)
        print(icon)
        #修改用户的头像icon字段
        stu = Student.query.get(id)
        stu.icon = name
        stu.save()
        # 重定向
        return redirect(url_for('app.all_stu'))
  • stus.html文件增加图片和编辑的标签
<td><img src="/static/media/{{ stu.icon }}" style="width: 100px"></td>
<td><a href="{{ url_for('app.edit_stu',id=stu.id)}}">编辑</a></td>
  • edit.html 文件内容如下:
{% extends 'base_main.html' %}

{% block content %}

<form action="" method="post" enctype="multipart/form-data">
    <p>姓名:{{stus.s_name}}</p>
    <p>头像:<input type="file" name="image"></p>
    <p><input type="submit" value="提交"></p>
</form>

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