美文网首页
【用树莓派搭建Django网站3】创建匿名访问页

【用树莓派搭建Django网站3】创建匿名访问页

作者: Geekero | 来源:发表于2021-01-06 17:43 被阅读0次

极客时间的吕老师Django课程的学习笔记

模板文件夹

创建base模板页

$mkdir templates
$cd templates/
$vi base.html
<!-- base.html -->

<h1 style="margin:auto;width:50%;">公司开放职位</h1>

<p></p>

{% block content %}
{% endblock %}

创建列表页

创建模板

(Django) 10:21 luohb@Studynode:~/Django/recruitment/jobs/templates 
$ls
base.html  joblist.html
(Django) 10:22 luohb@Studynode:~/Django/recruitment/jobs/templates 
$cat joblist.html 
{% extends 'base.html' %}

{% block content %}
  终于等到你,期待加入我们,用技术去探索一个新世界

{% if job_list %}
    <ul>
    {% for job in job_list %}
        <li>{{job.type_name}} <a href="/job/{{ job.id }}/" style="color:blue">{{ job.job_name }}</a> {{ job.city_name }} </li>
    {% endfor %}
    </ul>
{% else %}
    <p>No jobs are available.</a>
{% endif %}
    
{% endblock %}

在视图层中加入自定义的页面

View.py是将model渲染出来的环节

可以函数定义,也能用视图的类去定义
1. 用函数定义

$cat jobs/views.py 
from django.shortcuts import render
from django.http import HttpResponse
from django.template import loader

from jobs.models import Job
from jobs.models import Cities, JobTypes

# Create your views here.
def joblist(request):
    job_list = Job.objects.order_by('job_type') #从模型的object数据库里面获取,按职位类别排序
    #加载模板
    template = loader.get_template('joblist.html') #用模板的加载器加载
    #定义上下文
    context = {'job_list':job_list}
    
    for job in job_list:
        job.city_name = Cities[job.job_city][1]
        job.job_type = JobTypes[job.job_type][1]
    
    return HttpResponse(template.render(context))   #将上下文展现给用户

在jobs应用中定义joblist的访问路径

$cat jobs/urls.py 
from django.conf.urls import url
from jobs import views

urlpatterns = [
    # 职位列表 定义URL路径的映射
    url(r"^joblist/", views.joblist, name="Joblist")  #若访问的url以joblist为开头,则跳转到views.joblist
    
]

在整个工程中定义joblist的访问路径

$cat recruitment/urls.py 
"""recruitment URL Configuration

The `urlpatterns` list routes URLs to views. For more information please see:
    https://docs.djangoproject.com/en/3.1/topics/http/urls/
Examples:
Function views
    1. Add an import:  from my_app import views
    2. Add a URL to urlpatterns:  path('', views.home, name='home')
Class-based views
    1. Add an import:  from other_app.views import Home
    2. Add a URL to urlpatterns:  path('', Home.as_view(), name='home')
Including another URLconf
    1. Import the include() function: from django.urls import include, path
    2. Add a URL to urlpatterns:  path('blog/', include('blog.urls'))
"""
from django.conf.urls import include, url
from django.contrib import admin
from django.urls import path

urlpatterns = [
    url(r"^", include("jobs.urls")),
    path('admin/', admin.site.urls),
]

创建详情页

浅谈Django基础(HttpResponse、render、redirect)

创建模板

(Django) 16:47 luohb@Studynode:~/Django/recruitment 
$cat jobs/templates/job.html
{% extends 'base.html' %}

{% block content %}

<div style="margin:auto; width:50%;">

<a href="/joblist" style="color:blue">返回职位列表</a><p></p>

{% if job %}
    <div class="position_name">
        <h2>岗位名称: {{job.job_name}}</h2>
    
        城市:
        {{job.city_name}}<p></p>
    </div>
    <hr>
    <div class="position_responsibility", style="width:600px;">
        <h3>职位职责</h3>
        <pre style="font-size:16px">{{job.job_responsibility}}
        </pre>
        <p></p>
    </div><br>

    <hr>
    <div class="position_requirement" style="width:600px;">
        <h3>任职要求</h3>
        <pre style="font-size:16px">{{job.job_requirement}}
        </pre>
    </div>
    
    <br>

    <div class="apply_position">
        <input type="button" style="width:120px;background-color:lightblue;" value="申请"/>
    </div>
{% else %}
    <p>职位不存在</p>
{% endif %}


</div>
{% endblock %}

在视图中加入该模板进行渲染

(Django) 16:47 luohb@Studynode:~/Django/recruitment 
$cat jobs/views.py 
from django.shortcuts import render
from django.http import HttpResponse
from django.template import loader
from django.http import Http404
from jobs.models import Job
from jobs.models import Cities, JobTypes

# Create your views here.
def joblist(request):
    job_list = Job.objects.order_by('job_type') #从模型的object数据库里面获取,按职位类别排序
    #加载模板
    template = loader.get_template('joblist.html') #用模板的加载器加载
    #定义上下文
    context = {'job_list':job_list}
    
    for job in job_list:
        job.city_name = Cities[job.job_city][1]
        job.job_type = JobTypes[job.job_type][1]
    
    return HttpResponse(template.render(context))   #将上下文展现给用户

def detail(request, job_id):
    try:
        job = Job.objects.get(pk=job_id)
        job.city_name = Cities[job.job_city][1]
        #job.job_type = JobTypes[job.job_type][1]
    except Job.DoesNotExist:
        raise Http404("Job does not exist")
    
    return render(request, 'job.html', {'job':job}) #传值给view层

在应用url中注册该视图(定义访问地址)

(Django) 16:48 luohb@Studynode:~/Django/recruitment 
$cat jobs/urls.py 
from django.conf.urls import url
from jobs import views

urlpatterns = [
    # 职位列表 定义URL路径的映射
    url(r"^joblist/", views.joblist, name="Joblist"),  #若访问的url以joblist为开头,则跳转到views.joblist
    url(r"^job/(?P<job_id>\d+)/$", views.detail, name="detail"),
]

启动服务,查看效果

相关文章

网友评论

      本文标题:【用树莓派搭建Django网站3】创建匿名访问页

      本文链接:https://www.haomeiwen.com/subject/slgmnktx.html