需要解决的三个问题?

.



1.不够多的URL

  (1)正则表达式

  (2)\d 数字

/detail/123

/detail/(\d){3}  #限定3个数字

/detail/(\d+)   #限定多个数字

  (3)修改url

url(r'^detail/(?P<page_num>\d+)$', detail,name='detail'),

  

  • 给数字起个名字: page_num

  (4)修改view视图文件:#取出id为page_num这篇文章

def detail(request,page_num):
"""创建评论视图"""
if request.method == 'GET':
form = CommentForm() #实例化一个表单
if request.method == 'POST':
form = CommentForm(request.POST) #提交数据
print(form)
if form.is_valid(): #判断表单的数据是否通过验证;
print(form.is_valid) #返回布尔值,True 或者False
print(form.cleaned_data)
name = form.cleaned_data['name']
comment = form.cleaned_data['comment']
c = Comment(name=name,comment=comment) #把数据储存到Comment模型的实例c中
c.save() #保存到数据库
return redirect(to='detail') context ={}
comment_list = Comment.objects.all() #获取comment评论的所有数据
article = Article.objects.get(id=page_num) #取出id为page_num这篇文章
context['article'] = article
context['comment_list'] = comment_list
context['form'] = form
# print('11111') for testing
# print(form.errors)
# print('2222')
# print(form) comment_page = render(request,'article-detail.html',context) #render函数
return comment_page

  (5)详情页article-tail.html:替换数据库中捕获到的特定文章

        <div class="ui  segment padded container" >
<h1 class="ui header" style="font-family:'Oswald', sans-serif;font-size:40px">
{{ article.headline }}
</h1>
<p>
{{ article.content }}
</p>
</div>

  (6)如何跳转?修改fires_web.html的a标签

  • 文章标题  设置跳转
  • readmore  设置跳转
                <a href="{% url 'detail' article.id %}">
<h2 class="ui header">
{{ article.headline }}
</h2>
</a> <a href="{% url 'detail' article.id %}">
<i class="angle tiny double grey right icon">READMORE</i>
</a>

  (7)查看效果

    

    

    

    

    

2.怎么让评论只属于一篇文章

  (1)数据库对应关系

  • 一对多:一辆车--4个轮子

  

  • 多对一

  

  • 一对一:一辆车:一个引擎

    

  • 多对多:一个人可以购买多辆车;一辆车可以被多个人驾驶

    

  (2)文章,评论  :1对多关系

  • django中只有一对一,多对一,多对多关系
  • 实现一对多,可以反过来实现多对一
  • 一篇博客可以对应多个评论
  • 反过来在评论里实现
外键

belong_to = models.ForeignKey(to=Aritcle, related_name='under_comments',null=True,blank=True)

  

  

  

    

  (3)查询数据,数据装载到context中

  两个方法

  1. Article模型中查出我想要的数据:普通评论
  2. Comment模型中查出 :最佳评论

  (4)第一种方法:普通评论查找; Article模型

  

  •   article-tail.html 通过传入的  article 查找数据

    

    

  •   查看评论,admin后台修改评论的 belong to字段

   

  (6) 第二种:最优评论,comment模型中查找数据

  •   Model层:添加最优评论字段,布尔值,默认false
best_comment = models.BooleanField(default=False)  #最优评论字段布尔值

  

  •   更新数据库,后台查看

  • view视图,查找最优评论;best_comment返回的是list列表

  • 判断最优评论是否返回,取第一个评论

from django.shortcuts import render,HttpResponse,redirect
from firstapp.models import People,Aritcle,Comment
from django.template import Context,Template
from firstapp.form import CommentForm def first_try(request):
person = People(name='alxe',job='it')
html_string = '''
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>first_try</title>
</head>
<body>
<h1>Hello</h1>
<h3> {{ person.name }} </h3>
</body>
</html>
'''
t = Template(html_string)
c = Context({'person':person})
web_page = t.render(c) return HttpResponse(web_page) def index(request):
print(request)
print("==="*30)
print(dir(request))
print("==="*30)
print(type(request)) queryset = request.GET.get('tag')
print(queryset) if queryset:
article_list = Aritcle.objects.filter(tag=queryset) #过滤器
else:
article_list = Aritcle.objects.all() #获取Article数据库所有的数据 context = {}
context['article_list'] = article_list
index_page = render(request,'firstweb.html',context)
return index_page def detail(request,page_num):
"""创建评论视图"""
if request.method == 'GET':
form = CommentForm() #实例化一个表单
if request.method == 'POST':
form = CommentForm(request.POST) #提交数据
print(form)
if form.is_valid(): #判断表单的数据是否通过验证;
print(form.is_valid) #返回布尔值,True 或者False
print(form.cleaned_data)
name = form.cleaned_data['name']
comment = form.cleaned_data['comment']
c = Comment(name=name,comment=comment) #把数据储存到Comment模型的实例c中
c.save() #保存到数据库
return redirect(to='detail') context ={}
#最优评论
a = Aritcle.objects.get(id=page_num) #查找出该文章的id号
best_comment = Aritcle.objects.filter(best_comment=True, belong_to=a) #best_comment返回的是list列表
#select *from where best_comment=True and belong_to=a
if best_comment:
context['best_comment'] = best_comment[0] article = Aritcle.objects.get(id=page_num) #取出id为page_num这篇文章
context['article'] = article
context['form'] = form
comment_page = render(request,'article-detail.html',context) #render函数
return comment_page #comment_list = Comment.objects.all() #获取comment评论的所有数据 #context['comment_list'] = comment_list # print('11111') for testing
# print(form.errors)
# print('2222')
# print(form)
  • Template层:
  • 1.添加best_comment

    

  • 2.修饰
                  <div class="ui label">
<i class="icon fire">BEST</i> #添加label标签
</div>
  <div class="ui divider"></div>  #添加隔离直线

  

                  <div class="ui mini red left ribbon label">
<i class="icon fire">BEST</i>
</div>

  

  • 3.提交评论:错误
  • 第一个错误:redirect 缺少参数 page_num
  • 第二个错误:对应的article也要存储到comment

  

  • 4.redirect添加参数

        

  • 5,article的id存储到Comment中

  

    

def detail(request,page_num):
"""创建评论视图"""
if request.method == 'GET':
form = CommentForm() #实例化一个表单
if request.method == 'POST':
form = CommentForm(request.POST) #提交数据
print(form)
if form.is_valid(): #判断表单的数据是否通过验证;
print(form.is_valid) #返回布尔值,True 或者False
print(form.cleaned_data)
name = form.cleaned_data['name']
comment = form.cleaned_data['comment']
a = Aritcle.objects.get(id=page_num) #查找出该文章的id号
c = Comment(name=name,comment=comment, belong_to=a) #把数据储存到Comment模型的实例c中
c.save() #保存到数据库
return redirect(to='detail', page_num=page_num) context ={}
#最优评论
a = Aritcle.objects.get(id=page_num) #查找出该文章的id号
best_comment = Comment.objects.filter(best_comment=True, belong_to=a) #best_comment返回的是list列表
#select *from where best_comment=True and belong_to=a
if best_comment:
context['best_comment'] = best_comment[0] article = Aritcle.objects.get(id=page_num) #取出id为page_num这篇文章
context['article'] = article
context['form'] = form
comment_page = render(request,'article-detail.html',context) #render函数
return comment_page

3.分离视图

  (1)分离视图,加载文章内容和评论

  (2)分视图:post提交表单评论

def detail(request, page_num):
"""加载文章,评论视图"""
context ={}
form = CommentForm
a = Aritcle.objects.get(id=page_num) #最优评论 #查找出该文章的id号
best_comment = Comment.objects.filter(best_comment=True, belong_to=a) #best_comment返回的是list列表
#select *from where best_comment=True and belong_to=a
if best_comment:
context['best_comment'] = best_comment[0] article = Aritcle.objects.get(id=page_num) #取出id为page_num这篇文章
context['article'] = article
context['form'] = form
comment_page = render(request,'article-detail.html',context) #render函数
return comment_page def detail_comment(request, page_num):
"""post方法form表单提交"""
form = CommentForm(request.POST) #提交数据
print(form)
if form.is_valid(): #判断表单的数据是否通过验证;
#print(form.is_valid) #返回布尔值,True 或者False
#print(form.cleaned_data)
name = form.cleaned_data['name']
comment = form.cleaned_data['comment']
a = Aritcle.objects.get(id=page_num) #查找出该文章的id号
c = Comment(name=name,comment=comment, belong_to=a) #把数据储存到Comment模型的实例c中
c.save() #保存到数据库
return redirect(to='detail', page_num=page_num)

  (3)添加url

    url(r'^detail/(?P<page_num>\d+)/comment$',detail_comment,name='comment'),

  

  (4)Template层:添加action

  此处的comment是name=comment

        <form class="ui error tiny form" action="{% url 'comment' article.id %}" method="post">

  

  (5)错误信息没有打印

  

6 URL 实习文章链接跳转的更多相关文章

  1. 已经重写,源码和文章请跳转http://www.cnblogs.com/ymnets/p/5621706.html

    文章由于写得比较仓促 已经重写,源码和文章请跳转 http://www.cnblogs.com/ymnets/p/5621706.html 系列目录 前言: 导入导出实在多例子,很多成熟的组建都分装了 ...

  2. phpcms 内容——>评论管理 中添加 打开文章链接的 功能

    需要实现的功能:在后台管理系统中的 内容 下的——>评论管理  中添加 打开文章链接的 功能 1.数据库表是 v9_comment和v9_comment_data_1. v9_comment是被 ...

  3. WordPress 通过文章 URL 获取文章 ID

    // 获取当前文章链接,注意,在文章类型页面的主循环外使用标签时,如果没有指定 Post ID 参数,该标签将返回循环中最后一篇文章的 URL,而不是当前页面的固定链接,或者直接不返回结果,所以一般需 ...

  4. IT学子成长指导类文章链接(十二)

    链接:IT学子成长指导类文章链接(一)(二)(三) (四) (五)(六)(七)(八)(九)(十)(十一) "IT学子成长指导"类我收藏过的好文(十二期:至2014年6月17日) 程 ...

  5. 6)HTML中a链接跳转地址怎么写

    (1)看 thinkphp5的   附录--->助手函数  --->url 利用url进行书写地址跳转: 比如,你想跳转到cate控制器下的lst方法: <a href=" ...

  6. Geotrellis系列文章链接

    本文存放了我在博客园中撰写的Geotrellis系列文章链接,方便查阅! 一.geotrellis使用初探 二.geotrellis使用(二)geotrellis-chatta-demo以及geotr ...

  7. JS阻止链接跳转代码

    刷新后focus在第一个标签 onload="$('#input_email').focus(); " $(document).ready(function(){ $(" ...

  8. Mock Server文章链接

    Mock Server文章链接 2017-06-14 1 Dreamhead (Zheng Ye) Moco可以提供以下服务: HTTP APIs Socket APIs REST API GitHu ...

  9. wordpress文章链接怎么把默认的别名改成id形式和伪静态设置

    别名默认是文章标题,打不开,改成英文形式可以打开,但这样很不方便,还有可能重复.怎么改成按文章id自动生成相应链接呢 找到设置---固定链接----把默认的日期和名称型改成自定义结构把末尾的%post ...

随机推荐

  1. Python3爬虫04(其他例子,如处理获取网页的内容)

    #!/usr/bin/env python# -*- coding:utf-8 -*- import osimport reimport requestsfrom bs4 import Navigab ...

  2. XFS: Cross Frame Script (跨框架脚本) 攻击。

    一.Cross Frame Script (跨框架脚本) 攻击什么是Cross Frame Script?很简单,做个实验就知道了.把下面的这段HTML代码另存为一个html文件,然后用ie浏览器打开 ...

  3. linux上传、下载文件rz、sz命令

    1.介绍 sz命令是利用ZModem协议来从linux服务器传送文件到本地,一次可以传送一个或多个文件.相对应的从本地上传文件到Linux服务器,可以使用rz命令. 2.参数说明 -a,以文本方式传输 ...

  4. wget无法建立SSL连接

    在使用wget工具的过程中,当URL使用HTTPS协议时,经常出现如下错误:“无法建立SSL连接”. 这是因为wget在使用HTTPS协议时,默认会去验证网站的证书,而这个证书验证经常会失败.加上&q ...

  5. 笨办法学Python(三十一)

    习题 31: 作出决定 这本书的上半部分你打印了一些东西,而且调用了函数,不过一切都是直线式进行的.你的脚本从最上面一行开始,一路运行到结束,但其中并没有决定程序流向的分支点.现在你已经学了 if,  ...

  6. TP5.1:数据库的增删改查操作(基于面向对象操作)

    我们现实中对数据库的增删改查操作,都是使用模型类进行操作的(表名::),也就是面向对象操作,只有底层的代码用的是数据库操作(Db::table('表名')) 下面我将贴出模型类进行的增删改查操作,通过 ...

  7. Wampserver由橙变绿的解决过程

    因为C盘的内存问题,就重装了win7系统,那么就面临着很对软件要重新进行安装,安装wampserver时,再次遇到了服务器的图标一直是橙色的而不变绿色,安装包地址: http://download.c ...

  8. C语言中的特殊变量

    auto: 函数中的局部变量,动态地分配存储空间,数据存储在动态存储区中,在调用该函数时系统会给它们分配存储空间,在函数调用结束时就自动释放这些存储空间. register: 为了提高效率,C语言允许 ...

  9. 在jupyter notebook 中同时使用安装不同版本的python内核-从而可以进行切换

    在安装anaconda的时候,默认安装的是python3.6 但是cs231n课程作业是在py2.7环境下运行的.所以需要在jupyter notebook中安装并启用python2.7版本 方法: ...

  10. Open XML的上传、下载 、删除 ......文件路径

    /// <summary> /// Get download site, if download tempfolder not existed, create it first /// & ...