Django框架下配置视图信息

1.找到app下的views.py文件,我的app文件名为book,写出bookinfos函数
from django.http import HttpResponse
from book.models import *

# Create your views here.

def index(request):
    '''
    :param request: 请求对象,请求的所有信息,都在这个对象里
    :return:
    '''
    response = HttpResponse('request...%s'%request.method)
    return response

'''以下为显示所有书籍信息函数'''
def bookinfos(request):
    bookinfos = BookInfo.objects.all()
    response = HttpResponse(bookinfos)
    return response
2.在book文件下的urlpatterns中添加 url(r'^bookinfos$', views.bookinfos),
from django.conf.urls import include, url
from book import views

urlpatterns = [
    url(r'^index$', views.index),
    url(r'^bookinfos$', views.bookinfos),   #添加
]

以上为没有配置模板,网页只能显示文字,无法美化页面


引用模板

1.定义模板
创建和manage.py同级的templates文件,并在该文件下创建book同名文件

在settings.py里用 os.path.join() 设置模板路径

在book下创建html
在book文件下urls.py中添加,逗号前的参数为正则匹配网页,逗号后面参数为 文件名点函数名
2.在book文件夹下views.py中添加bookinfos_list函数,其最下方函数111和上方注释的内容222等价
from django.http import HttpResponse
from book.models import *
from django.template import loader,RequestContext    
from django.shortcuts import render

# Create your views here.
def index(request):
    '''
    :param request: 请求对象,请求的所有信息,都在这个对象里
    :return:
    '''
    response = HttpResponse('request...%s'%request.method)
    return response

'''
def bookinfos_list(request):       #111
    #查询所有书
    bookinfos = BookInfo.objects.all()
    #加载模板
    template = loader.get_template('book/bookinfos_list.html')
    #创建上下文对象,定义好参数,向模板传输参数
    context = RequestContext(request,{'bookinfos':bookinfos})
    #渲染模板
    content = template.render(context)
    #创建响应对象
    response = HttpResponse(content)
    #返回响应
    return response
'''
def bookinfos_list(request):        #2222
    bookinfos = BookInfo.objects.all()
    response = render(request=request,template_name='book/bookinfos_list.html',context={'bookinfos':bookinfos})
    return response



同时改动所在html的内容,代码如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    bookinfo_list.html<hr/>
    {{ bookinfos }}
    <ul>
        {% for bookinfo in bookinfos %}
            <li>{{bookinfo.id}}-{{bookinfo.btitle}}</li>
        {% endfor %}
    </ul>
</body>
</html>

页面效果


实现查询所有人物和详细信息

在book文件夹下urls.py下添加:

注意!这里正则表达式的分组,django自动将分组的值(group)传给后边的函数!
url(r'^heroinfo_detail/(\d+)$', views.heroinfos_detail),

在book文件夹下的views.py中添加:

hid就是分组的值的形参
def heroinfo_detail(request,hid):
    return HttpResponse(hid)

页面效果测试如下



可跳转任何页面

修改views.py

#根据人物id查询详细信息
def heroinfo_detail(request,hid):
    #准备数据
    heroinfo = HeroInfo.objects.get(id=hid)
    #渲染数据并响应
    response = render(request=request, template_name='book/heroinfo_detail.html', context={'heroinfo': heroinfo,'title':'详细信息'})
    return response

创建heroinfo_detail页面:

<body>
    <table>
        <tr>
            <td>名字:</td>
            <td>{{ heroinfo.hname }}</td>
        </tr>
        <tr>
            <td>性别:</td>
            {% if heroinfo.hgender == True %}
                <td>男</td>
            {% else %}
                <td>女</td>
            {% endif %}
        </tr>
        <tr>
            <td>简介:</td>
            <td>{{heroinfo.hcontent}}</td>
        </tr>
        <tr>
            <td>所属书的名字:</td>
            <td>{{heroinfo.hbookinfo.btitle}}</td>
        </tr>
    </table>
</body>

创建heroinfos_list相关页面:

<body>
    heroinfo_list.html<hr/>
    <ul>
        {% for heroinfo in heroinfos %}
        <li><a href="/heroinfo_detail/{{ heroinfo.id}}">{{heroinfo.id}}-{{heroinfo.hname}}</a></li>
        {% endfor %}
    </ul>
</body>

增加urls.py下 heroinfos_list相关代码:

url(r'^heroinfos_list$', views.heroinfos_list),

增加views.py下 heroinfos_list相关代码:

def heroinfos_list(request):
    heroinfos = HeroInfo.objects.all()
    response = render(request=request,template_name='book/heroinfos_list.html',context={'heroinfos':heroinfos,'title':'显示所有英雄'})
    return response

页面显示效果:


点击 至尊宝 跳转页面 并显示详细信息:


(不是重点)去除模板的硬编码:

在开发中,如果一些超链接都是硬编码,也就是说不是动态的,如果地址被改,链接网页将无法打开,例子如下:

html页面中的跳转链接:
<a href="/heroinfo_detail/{{ heroinfo.id}}">
book/urls.py文件下的匹配代码,中间添加111,使之无法匹配:
url(r'^heroinfo_111detail/(\d+)$', views.heroinfo_detail)
无法匹配网页

解决办法:
先在自己项目下的urls.py添加namespace,内容随便写,我这里是book:


url(r'^', include('book.urls',namespace='book'))

然后再book/urls.py下添加代码name:

url(r'^heroinfo_111detail/(\d+)$', views.heroinfo_detail,name='details')

最后在html页面中的跳转链接修改成如下代码:

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

推荐阅读更多精彩内容

  • 切换到创建项目的目录 cd C:\Users\admin\Desktop\DjangoProject创建名为pr...
    在努力中阅读 3,259评论 2 3
  • 此段内容简要来自自强学堂的教程详情请查询自强学堂 一、 后台的运作流程 接收request请求 处理数据 获取请求...
    coder_ben阅读 5,243评论 6 56
  • 创建一个项目bcxt_tmpl创建一个应用learn配置urli.在应用下创建一个urls.py模块i.把我们...
    木头的男人阅读 408评论 0 0
  • (一)、启动服务器 (二)、创建数据库表 或 更改数据库表或字段 Django 1.7.1及以上 用以下命令 1....
    夏天夏星阅读 5,625评论 0 17
  • 我是谁我在哪儿? 用户是谁?用户要干吗?用户喜欢干吗? (1)分析项目资料 (2)查看BI数据 (3)场景化分析~...
    Odysseus杨阅读 147评论 0 3