Flask - 用户留言板

留言板模型

  • 一个用户可以有多个留言, 如果没有登录, 显示的是匿名留言
# 留言板
class MessageBoard(db.Model):
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    content = db.Column(db.String(255), nullable=False)
    mdatetime = db.Column(db.DateTime, default=datetime.now)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
    user = db.relationship('User', backref='message')

模板

Searching...
{% endblock %}

{% block scripts %}
    {{ super() }}
    <script>
        $(function () {
            //文本域
            $('textarea[name="board"]').focus(function () {
                $(this).val("")
            })

        })
    </script>
{% endblock %}

函数

# 留言板
@user_bp.route('/board', methods=['GET', 'POST'])
def show_board():
    msg_board = MessageBoard()
    uid = session.get('uid', None)
    user = None
    if uid:
        user = User.query.get(uid)
    if request.method == 'POST':
        content = request.form.get('board')
        # 获取提交的留言内容
        msg_board.content = content
        # 存储
        if uid:
            msg_board.user_id = uid

        db.session.add(msg_board)
        db.session.commit()
        return redirect(url_for('user.show_board'))
    else:
        boards = msg_board.query.all()
        return render_template('user/board.html', user=user, boards=None)

管理留言- 删除留言

@user_bp.route('/board_delete')
def del_board():
    board_id = request.args.get('bid')
    print()
    msg_board = MessageBoard.query.get(board_id)
    db.session.delete(msg_board)
    db.session.commit()
    return redirect(url_for('user.center'))
<td><a href="{{ url_for('user.del_board') }}?bid={{ board.id }}">删除留言</a></td>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值