当前位置: 首页 > news >正文

首页列表显示全部问答,完成问答详情页布局


  1. 首页列表显示全部问答:
    1. 将数据库查询结果传递到前端页面 Question.query.all()
    2. 前端页面循环显示整个列表。
    3. 问答排序
  2. 完成问答详情页布局:
    1. 包含问答的全部信息
    2. 评论区
    3. 以往评论列表显示区。
  3. 在首页点击问答标题,链接到相应详情页。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>
        {% block logintitle %}{% endblock %}
        {% block registertitle %}{% endblock %}
       啦啦啦</title>

    <link rel="stylesheet" type="text/css" href="{{ url_for('static',filename='css/base.css') }}">
    <script src ="{{ url_for('static',filename='js/base.js') }}"></script>
{% block head %}
{% endblock %}
</head>
<body id="myBody">

<nav>
    

    <img id="myOnOff" οnclick="mySwitch()" 
src="https://www.runoob.com/images/pic_bulbon.gif" height="20" width="20px">
    <a href="{{ url_for('shouye') }}">首页</a>
    <a href="{{ url_for('wenda') }}">发布问答</a>
    <a href="{{ url_for('shouye') }}">听一听</a>

    <input type="text" name="search">
    <button type="submit">看一看</button>

        <ul class="nav nav-tabs">
            <li><a href="{{ url_for('lx') }}">首页</a></li>
 

    {% if username %}
         <a class="right" href="#">{{ username }}</a>
         <a href="{{ url_for('logout') }}">注销</a>
    {% else %}
         <a class="right" href="{{ url_for('login') }}">登录</a>
         <a href="{{ url_for('zhuce') }}">注册</a>
    {% endif %}

</nav>


    {% block loginhead %}{% endblock %}
    {% block registerhead %}{% endblock %}





    <p class="text1">哈哈哈<br>
   by:厚脸皮羊
    </p>

</body>
</html>

 

from flask import Flask,render_template,request,redirect,url_for,session
from flask_sqlalchemy import SQLAlchemy
import config


app = Flask(__name__)
app.config.from_object(config)
db = SQLAlchemy(app)


class User(db.Model):
    __tablename__ = 'user'
    id = db.Column(db.Integer,primary_key=True,autoincrement=True)
    username = db.Column(db.String(20),nullable=False)
    password = db.Column(db.String(20),nullable=False)
#db.create_all()





@app.route('/')
def base():
    return render_template('base.html')

@app.route('/shouye/')
def shouye():
    return render_template('shouye.html')

@app.route('/login/',methods=['GET','POST'])
def login():
    if request.method == 'GET':
        return render_template('login.html')
    else:
        usern = request.form.get('username')
        passw = request.form.get('password')
        user = User.query.filter(User.username == usern).first()
        if user:
            if user.password == passw:
                session['user'] = usern
                return redirect(url_for('shouye'))
            else:
                return u'password error'
        else:
            return u'username is not existed.'


@app.context_processor
def mycontext():
    usern=session.get('user')
    if usern:
        return {'username':usern}
    else:
        return {}


@app.route('/logout')
def logout():
    session.clear()
    return redirect(url_for('shouye'))


@app.route('/zhuce/',methods=['GET','POST'])
def zhuce():
    if request.method == 'GET':
        return render_template('zhuce.html')
    else:
        usern = request.form.get('username')
        passw = request.form.get('password')
        user = User.query.filter(User.username == usern).first()
        if user:
            return u'username existed'
        else:
            user1 = User(username=usern, password=passw)
            db.session.add(user1)
            db.session.commit()
            return redirect(url_for('login'))



@app.route('/wenda/')
def wenda():
    return render_template('wenda.html')


@app.route('/')
def lx():
    context = {
       'question':Ques.query.all()
 
    }
    return render_template('lx3.html',**context)
 
@app.route('/detail/')
def detail():
    # quest=Ques.query.filter(Ques.id == Ques_id).first()
    return render_template('detail.html')



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

 

转载于:https://www.cnblogs.com/xy123ing/p/7987942.html

相关文章:

  • POJ 2057 The Lost House 树形DP+贪心
  • JAVA Http Basic auth
  • 如何两个栈实现队列?两个队列实现栈?
  • Java之字符流操作-复制文件
  • 判断是否长按某一键
  • 【Android】封装一个简单好用的打印Log的工具类
  • centos7 防火墙 开启端口 并测试
  • 设计模式
  • IDA.快捷键_ZC收集
  • 直接从google中引入jquery.js
  • Sql注入攻击
  • linux下vsftpd客户端时间不一致问题
  • 3.2 使用STC89C52控制MC20发送短信
  • POJ 2823 Sliding Window 单调队列
  • 别人做的扫地机器人,有机会我也想搞一台!
  • SegmentFault for Android 3.0 发布
  • [deviceone开发]-do_Webview的基本示例
  • Angular数据绑定机制
  • axios请求、和返回数据拦截,统一请求报错提示_012
  • ComponentOne 2017 V2版本正式发布
  • ES学习笔记(10)--ES6中的函数和数组补漏
  • MySQL QA
  • Python socket服务器端、客户端传送信息
  • thinkphp5.1 easywechat4 微信第三方开放平台
  • Yeoman_Bower_Grunt
  • 从0搭建SpringBoot的HelloWorld -- Java版本
  • 从零开始在ubuntu上搭建node开发环境
  • 简单实现一个textarea自适应高度
  • 开发基于以太坊智能合约的DApp
  • 手写双向链表LinkedList的几个常用功能
  • 微服务核心架构梳理
  • 学习笔记DL002:AI、机器学习、表示学习、深度学习,第一次大衰退
  • 一天一个设计模式之JS实现——适配器模式
  • 掌握面试——弹出框的实现(一道题中包含布局/js设计模式)
  • 白色的风信子
  • linux 淘宝开源监控工具tsar
  • 微龛半导体获数千万Pre-A轮融资,投资方为国中创投 ...
  • #define、const、typedef的差别
  • #鸿蒙生态创新中心#揭幕仪式在深圳湾科技生态园举行
  • $.type 怎么精确判断对象类型的 --(源码学习2)
  • (003)SlickEdit Unity的补全
  • (C语言)输入一个序列,判断是否为奇偶交叉数
  • (附源码)计算机毕业设计SSM疫情社区管理系统
  • (附源码)流浪动物保护平台的设计与实现 毕业设计 161154
  • (三)mysql_MYSQL(三)
  • (一)kafka实战——kafka源码编译启动
  • (最优化理论与方法)第二章最优化所需基础知识-第三节:重要凸集举例
  • . Flume面试题
  • .360、.halo勒索病毒的最新威胁:如何恢复您的数据?
  • .NET Framework与.NET Framework SDK有什么不同?
  • .NET Standard 的管理策略
  • .Net Web项目创建比较不错的参考文章
  • .Net多线程总结
  • .NET命名规范和开发约定
  • [.NET 即时通信SignalR] 认识SignalR (一)