现在存在一个问题,就是在未登陆的情况下,就可以使用发布问答功能,这个肯定是不行的,所以我们得进行一些限制,比如在没有登录的情况下,无法访问这个网页,我们可以看一下这个限制该如何编写
if not g.user:
return redirect(url_for('auth.login'))
我们可以进行登录判断,就是如果处于无登录就是在session中没有user_id,那么这个问答页面就得返回到登陆页面
但这不管完美,因为你现在是一个页面,就是问答页面,如果还有一个评论页面,那么是不是得在评论页面也得写上那个上面的的代码,如果我有上百上千,那么是不是上百上千的页面我都得加上这个代码,但实际上我们可以加一个装饰器,就可以完美的解决这个问题
可以看一下下面装饰器的实现过程(装饰器就是在函数里面定义函数,然后返回值是这个定义的函数 )
def login_required(func):
#保留func的信息
@wraps(func)
#func(v,b, a = 3)
def inner(*args,**kwargs):
if g.user:
return func(*args,**kwargs)
else:
return redirect(url_for('auth.login'))
return inner
# @login_required
# def public_question(question_id):
# pass
#
#
# # 上面代码等价于下面的代码
# login_required(public_question)(question_id)#这个代码完成后得到的是一个新的函数
就是在装饰器内存在g.user存在,得正常执行下面的函数,如果不存在,就会从定向到其他页面
装饰器的个人理解
这是我对装饰器的认识,调用装饰器后会returnB 然后直接执行B,B函数包含了被装饰函数func,就可以会执行func,然后返回
接下来就是对首页内容的呈现
首先整体逻辑思路:
1.首先还是的先从数据库中获取数据,然后再对数据进行呈现,那么在后端从数据库中国获取的数据该如何传递给前端呢,这时候我们就得通过下面代码来实现呈现
其中我们先可以从简单的开始,可以先呈现,然后一条问答数据,然后可以发特殊问题一般化,,这样就可以得到所有问答的页面呈现
2.代码具体实现
#一般来说,函数可以作为前后端的结构,这里我们使用了向render_template传参的方式来进行传递一个后端数据
@bp.route("/")
def index():
questions = QuestionModel.query.order_by(QuestionModel.creat_time.desc()).all()
return render_template('index.html',questions = questions)
我们把问答都放一个数据库QuestionModel的表中,通过查询数据库就可以获取到问答数据,然后通过渲染模板的方式把数据传送到前端html中,前端再根据jinja2模板可以对数据进行全方位的展示
红框框前面的便是修改后代码的数据
暂缓页面分页技术的实现
问答页面渲染
这个就是如何在点击首页的标题后跳转到detailed.html页面
这里我们还是根据base来修改detailed.html把其特有的部分block出来就可以了