Django后台项目开发实战四

用户可以浏览工作列表以及工作详情

第四阶段

在 jobs 文件夹下创建 templates 文件夹,在里面创建 base.html 网页,内容如下

html 复制代码
<!-- base.html -->
<div style="text-align:center;">
    <h1 style = "margin:auto; width:50%;">开放职位</h1>
</div>

{% block content %}
{% endblock %}

再创建 joblist.html 网页,内容如下

html 复制代码
{% extends 'base.html' %}
{% block content %}

{% if job_list %}
    <ui>
    {% 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 %}
    </ui>
{% else %}
    <p>No jobs are avaiable.</p>
{% endif %}

{% endblock %}

然后打开 view.py 文件,创建职位列表,注册到网页

python 复制代码
from django.shortcuts import render
from django.http import HttpResponse
from django.template import loader

from jobs.models import Job,Cities,JobTypes

def joblist(requset):
    job_list = Job.objects.order_by('job_type')
    template = loader.get_template('joblist.html')
    context = {'job_list' : job_list}

    for job in job_list:
        job.city_name = Cities[job.job_city]
        job.type_name = JobTypes[job.job_type]

    return HttpResponse(template.render(context))

在 jobs 文件夹下创建 urls.py 文件,添加 path

python 复制代码
from django.urls import path
from jobs import views

urlpatterns = [
    path('joblist/',views.joblist, name="joblist")
]

最后在 recruitment 文件夹下的 urls.py 添加路由,完成配置

python 复制代码
from django.contrib import admin
from django.urls import path
from django.conf.urls import include

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

现在职位列表可以展示出来了,运行效果图:

接下来我们完成显示职位的详细描述

和上面的流程一样,先添加网页模板,在 templates 文件夹里新建 job.html 网页

html 复制代码
{% extends 'base.html' %}
{% block content %}

<div style="margin: auto; width: 50%;">
    <a href="/joblist" style="color: blue">返回职位列表</a>
{% if job %}
    <div class="position_name">
        <h2>岗位名称:{{ job.job_name }}</h2>
        城市:{{ job.city_name }}
    </div>
    <hr>
    <div class="position_responsibility" style="width: 600px;">
        <h3>岗位职责:</h3>
        <pre style="font-size: 16px">{{ job.job_responsibility }}</pre>
    </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 %}

然后打开 view.py 文件,添加职位详细信息,注册到网页

python 复制代码
from django.http import Http404

def detail(request,job_id):
    try:
        job = Job.objects.get(pk=job_id)
        job.city_name = Cities[job.job_city][1]
    except Job.DoesNotExist:
        raise Http404("Job does not exist")

    return render(request,'job.html',{'job':job})

然后打开 urls.py 文件,添加 path

python 复制代码
urlpatterns = [
    ...
    path('job/<int:job_id>/',views.detail, name="detail")
]

现在职位详情页可以展示出来了,运行效果图:

第四阶段就完成啦!

相关推荐
kvo7f2JTy2 分钟前
.NET 11 预览版1:CoreCLR 在 WebAssembly 上的全面集成与性能突破
服务器·.net·wasm
做cv的小昊2 分钟前
【conda】打包已有conda环境并在其他服务器上搭建
运维·服务器·python·conda·运维开发·pip·开发
Vfw3VsDKo3 分钟前
Android设备搭建本地RTSP服务器(基于live555)
android·运维·服务器
YYYing.5 分钟前
【Linux/C++网络篇(二) 】TCP并发服务器演进史:从多进程到Epoll的进化指南
linux·服务器·网络·c++·tcp/ip
daemon.qiang9 分钟前
麒麟系统v10服务器版本支持intel 12th集成显卡
服务器·图形渲染
@迷糊10 分钟前
服务器电源扫盲
服务器
djBe17esS11 分钟前
实战:Java 日志中打印服务器 IP,快速区分多服务器日志归属
java·服务器·tcp/ip
Jp7gnUWcI23 分钟前
.NET Win32磁盘动态卷触发“函数不正确”问题排查
运维·服务器·.net
林姜泽樾26 分钟前
linux入门第十八章,IP、主机名、域名解析
linux·服务器·tcp/ip
数智化管理手记9 小时前
精益生产中的TPM管理是什么?一文破解设备零故障的密码
服务器·网络·数据库·低代码·制造·源代码管理·精益工程