当前位置: 移动技术网 > IT编程>脚本编程>Python > 使用pycharm开发web——django2.1.5(四)视图和模板相关

使用pycharm开发web——django2.1.5(四)视图和模板相关

2019年06月21日  | 移动技术网IT编程  | 我要评论

南宁公交车路线查询,改造黑帮大小姐txt,炮灰 绿蜡

刘老师说这块很重要。。。。。

应该是很重要,大概看了一下,这里面关于views中函数作用,大概看来可能就是相应请求,传入数据和跳转,基本功能上貌似这些框架都差不多吧(其实我并没用过3个框架以上。。。。)

从功能上想,网站必然包含了许多实现具体功能和数据展示的页面,而现在在做的就是构成这些。

那么一个网页他的样子(模板)就是html,那么他的灵魂在这里就是views。这样想似乎就比较清楚。

在构思的时候都是默认躯体存在,设计者需要先设置他的灵魂

在polls/views.py中添加如下函数:

def detail(request, question_id):
    return httpresponse("you're looking at question %s." % question_id)

def results(request, question_id):
    response = "you're looking at the results of question %s."
    return httpresponse(response % question_id)

def vote(request, question_id):
    return httpresponse("you're voting on question %s." % question_id)

这里可以大概得出结论,我们在views.py中做的所有函数几乎都是返回了一个httpresponse对象

这个对象呢有这样几个属性:

content:表示返回的内容,字符串类型

charset:表示response采用的编码字符集,字符串类型

status_code:响应的http响应状态码 404什么的

content-type:指定输出的mime类型


写好这几个函数,也就需要配置一下二级路由,服务器找到app  polls的路径我理解为了这里的一级路由,是在pysite(我的web项目名)的urls里面配置的,那么当在app之下在有页面时候同样就需要在polls的urls中进行路径配置,好让服务器找到对应的地址。

from django.urls import path

from . import views

urlpatterns = [
    # ex: /polls/
    path('', views.index, name='index'),
    # ex: /polls/5/
    path('<int:question_id>/', views.detail, name='detail'),
    # ex: /polls/5/results/
    path('<int:question_id>/results/', views.results, name='results'),
    # ex: /polls/5/vote/
    path('<int:question_id>/vote/', views.vote, name='vote'),
]
<int:question_id> 这个东西,这样想,某个int类型的值,传进来并将其赋给question_id变量,还记得前面我们在views中写的函数吗,其中参数除了request之外还有一个question_id,简直伏笔,刘老师真骚人也。。。。
牛人写书往往也这样,开始看的你头疼,知道看到某处,武功及大成,融会贯通,一通百通。
这时候你在localhost:8000/polls/某个数字 访问的时候就会对应的出现不同效果,看detail函数就能理解到。
这些能看得到就证明灵魂已经能运转了,虽然他还没有躯体,可能就像一个嗷嗷待哺的贾维斯一样吧,史塔克牛逼
path()达成的效果是这样的,这里已经是在找二级路由也就是,从你地址栏输入的polls/后面开始找满足参数里面那个正则形式的,就调用视图下某个函数
比如在
path('', views.index, name='index'),即为如果polls/后面莫得东西,那就走index函数去进行跳转传参,
path('<int:question_id>/', views.detail, name='detail'),如果polls/后面只跟了一个数字 那就调用那个views中叫detail的函数
and so on 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

然后刘老师搞了个能调用数据库中信息展示的函数,也就是把detail进行了改变,让页面能正儿八经做些事,而不是傻冒的打印一句绝大多数字不会改变的字符串
更改一下vies.py
from django.http import httpresponse

from .models import question


def index(request):
    latest_question_list = question.objects.order_by('-pub_date')[:5]
    output = ', '.join([q.question_text for q in latest_question_list])
    return httpresponse(output)

学过mysql你看见order by 就知道他要排序,根据时间的相反数,鬼知道为什么要用1970年到其日期之间的毫秒数,知道也不想理解,内心无法接收。所以他这里根据时间的相反数,可以想象,这个毫秒数越大时间越“新”,这里不用多想,框架后面对应的必然有一条order by语句,那个是要传一个列进去,这句话默认是升序的,如果这样的话,最新的时间就会排在最下面了。而我们想要的影噶是把最新的放在上面,后来者居上,这就解释得通了。(强行解释)

好的detail有了他的灵魂,你还需要给他一个躯体,这怎么感觉像是在看复仇者联盟2一样,旺达的老公要出来了,搞了这么久原来是托尼给贾维斯找了个女朋友,还送了个定情原石。哦!woc,女朋友,,,,,女。。。。。。。,是啊百合是多么纯洁而浪漫

咳咳,继续

django中提到一个渲染,说白了就是用一个httpresponse对象把东西传过去。然后页面再执行一些东西,页面,想想能干啥?不就是显示屏和输入设备的功能吗,给你看和让你点让你敲。

在这里,当我们创建项目的时候就有一个雪青色的文件夹放在那里,叫做templates。。。。。(邪恶),这里只是拿出来说这个名字,你要放的模板不在这里,你需要在你对应的app的目录下面新建一个文件夹叫做templates,而且在这之下新建一个和app同名的文件夹比如这里的路径是polls/templates/polls/

这里是你接下来要存放模板的地方,这样做是为了解决一些共有问题,很多时候集体主义状态很乱,虽然现实中多数由于管理者能力不足导致,但是本身确实有局限性,比如这里说你们都是女生,那么单说女生,谁知道找哪一位呢?集体主义有时候强制把一些东西变成了公共状态,而如果设定不是很合理就必然会乱,想想感觉得到,当然事物是相对的,集体的弊端需要个人弥补,个人也有难以单独实现的事情。阴阳调和即可。

所以请按照这个规范来创建,圈里都这样 干,你干是不干?刘老师教程说叫做独立命名空间,帅气

由于接下来要在index页面搞事情,

先吧index的灵魂写好:

数据库是要自己搞的哦,具体参考前面的篇章

在views.py中修改:

def index(request):
    latest_question_list = question.objects.order_by('-pub_date')[:5]
    template = loader.get_template('polls/')
    context = {
        'latest_question_list': latest_question_list,
    }
    return httpresponse(template.render(context, request))

 

创建好目录之后进去新建一个html文件

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>title</title>
</head>
<body>
    {% if latest_question_list %}
    <ul>
    {% for question in latest_question_list %}
{#被注释 <li><a href="/polls/{{ question.id }}/">{{ question.question_text }}</a></li>#}
        <li><a href="{% url 'detail' question.id %}">{{ question.question_text }}</a></li>
    {% endfor %}
    </ul>
{% else %}
    <p>no polls are available.</p>
{% endif %}
</body>
</html>

这就是现在的效果,里面加了一个超链接,超链接的内容是从数据库中查询到的question_text的内容,如果想去做些很好看的页面,建议去mooc看html、css等学一翻就好,人活着没意思,让你前进的是好奇心。

然后刘老师告诉你,刚才的写法过时了,嘿嘿,我们现在用render()

每次自己看东西到这种就感觉很******,但是好在这样是一个理解的过程

来,再改views.py

def index(request):
    latest_question_list = question.objects.order_by('-pub_date')[:5]
    context = {'latest_question_list': latest_question_list}
    return render(request, 'polls/', context)

但是注意了,这里几个不同的方法,最终实际上都是一个httpresponse对象,是不是一种万物归一的感觉,茅塞顿开

 

然后刘老师讲了异常处理,这里也就是404的而已

开始是这样的(views.py):

from django.http import http404
from django.shortcuts import render

from .models import question
# ...
def detail(request, question_id):
    try:
        question = question.objects.get(pk=question_id)
    except question.doesnotexist:
        raise http404("question does not exist")
    return render(request, 'polls/detail.html', {'question': question})

然后是这样的:

from django.shortcuts import get_object_or_404, render

from .models import question
# ...
def detail(request, question_id):
    question = get_object_or_404(question, pk=question_id)
    return render(request, 'polls/detail.html', {'question': question})

一jio吧try except踢到九霄云外,就用而言,请你直接上高级的。

好的,现在再去写一个detail的模板

看看视图中detail方法(函数)中的语句,从数据库表(类)question model对应的表中取到主键等于传入question_id的question对象并把它字典形式传入并渲染模板

detail.html 放在哪里就不用说了,都是polls的模板

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>detail</title>
</head>
<body>
<h1>{{ question.question_text }}</h1>
    <ul>
    {% for choice in question.choice_set.all %}
        <li>{{ choice.choice_text }}</li>
    {% endfor %}
    </ul>
</body>
</html>

由于在写model时候说过的,这里的question和choice是有所关联的,两个类就可以相互去做一些查询,算是django的骚操作了,所以当把question传过来后,detail.html就开始疯狂的使用他,而遍历数据却在choice的表中

这就很有意思了

那么效果是:

删除模板中硬编码的urls

什么叫硬编码的urls?打个比方,有一波人卖房子的人,另一波叫卖房子的人,卖房子原来自己联系买家,结果这些人又很恶心,一会儿想买一会儿不想买,搞来搞去,同一个买家找人找的快费劲死,后来这些卖家全干掉,交给中介去高了,对于买家来说,只要应付中介就完事了。。。。。说了好长

这里的硬核url就是那种耐冲击性很差的存在,这个词好像是在水污染控制工程里面第一次学,某些东西无法抵抗水质的突变

当我们的路径发生变化的时候,如果html页面上直接填写的是页面路径,那就需要重新修改这个地方,一处改一个,一万处就凉凉,所以这里要用别名

对比一下index中的两句:

{#被注释 <li><a href="/polls/{{ question.id }}/">{{ question.question_text }}</a></li>#}
        <li><a href="{% url 'detail' question.id %}">{{ question.question_text }}</a></li>

在urls.py中我们有写过name=""这个地方,这里就是起别名,最终用到html这里很舒服,这是要修改的地方,这样的方法是很提高效率的

 

url命名空间:

在polls/urls.py中加入变量app_name='polls'

那么此时再对文件中的那个超链接地址进行修改吧,指明,是polls的detail。

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>title</title>
</head>
<body>
    {% if latest_question_list %}
    <ul>
    {% for question in latest_question_list %}
{#        <li><a href="/polls/{{ question.id }}/">{{ question.question_text }}</a></li>#}
        <li><a href="{% url 'polls:detail' question.id %}">{{ question.question_text }}</a></li>
    {% endfor %}
    </ul>
{% else %}
    <p>no polls are available.</p>
{% endif %}
</body>
</html>

 

from django.urls import path
from . import views

app_name = 'polls'
urlpatterns = [
    path('', views.index, name='index'),
    # ex:/polls/5
    path('<int:question_id>/', views.detail, name='detail'),
    # ex:/polls/5/results
    path('<int:question_id>/results/', views.results, name='results'),
    # ex:/polls/5/vote/
    path('<int:question_id>/vote/', views.vote, name='vote'),
    # 添加新的单词'specifics'有了中介之后这里就是改了也无妨
    path('specifics/<int:question_id>/', views.detail, name='detail'),
]

两点了睡了睡了

 

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网