???♂? 個人主頁: @計算機魔術師
????? 作者簡介:CSDN內容合伙人,全棧領域優(yōu)質創(chuàng)作者。
?? 推薦一款找工作神器網(wǎng)站: 寶藏網(wǎng)站 |筆試題庫|面試經(jīng)驗|實習招聘內推|
該文章收錄專欄
?—【Django | 項目開發(fā)】從入門到上線 專欄—?
一、查看簡歷詳情
由于前文所開發(fā)的簡歷投遞,并將簡歷進入到面試流程,在后臺中我們是只能看到其
resume簡歷 模型
與candidate候選人
中相同字段信息的,關于個人能力描述,項目經(jīng)驗等都沒有錄入,此時我們希望hr能夠看到完整簡歷
1. 添加類視圖
class ResumeDetailView(DetailView):
"""顯示簡歷詳情"""
model = Resume
template_name = 'resume_detail.html'
context_object_name = 'resume'
2. 添加路由
from django.urls import re_path
from jobs import views
app_name = 'jobs'
urlpatterns = [
re_path(r'^$', views.jobList, name='jobList'),
re_path(r'^job/(?P<id>[\d]+)/$', views.jobItem, name='jobItem'),
re_path(r'^resume/add/$', views.ResumeCreateView.as_view(), name='resumeForm'),
re_path(r'^resume/(?P<pk>[\d+])/$', views.ResumeDetailView.as_view(), name='resumeDetail')
]
3. 添加模板文件
{% extends 'base.html' %}
{% block load %}
{# Load the tag library #}
{% load bootstrap4 %}
{# Load CSS and JavaScript #}
{% bootstrap_css %}
{% bootstrap_javascript jquery='full' %}
{# Display django.contrib.messages as Bootstrap alerts #}
{% bootstrap_messages %}
{% endblock %}
{% block title %}Resume_form {% endblock %}
<style>
{% block style %}
.bd-placeholder-img {
font-size: 1.125rem;
text-anchor: middle;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
@media (min-width: 768px) {
.bd-placeholder-img-lg {
font-size: 3.5rem;
}
}
{% endblock %}
</style>
<!-- Custom styles for this template -->
{% block body %}
<body class="bg-light">{% endblock %}
{% block content %}
<div class="container">
<!--header-->
<div class="py-5 text-center">
<img class="d-block mx-auto mb-4" src="https://p0.ssl.img.360kuai.com/t011ad70fa7f3d778f4.jpg?size=650x433"
alt="" width="72"
height="72">
<h2>簡歷信息</h2>
</div>
<!--resume-->
</div>
<div style="background-color : #f4f4f0" class=" sm:mx-32 lg:mx-32 xl:mx-72 ">
<div class="flex justify-between container mx-auto">
<div class="w-full">
<div class="mt-4 px-4">
<h1 class="text-3xl font-semibold py-7 px-5">Resume in detail</h1>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
username
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.username }}"></textarea>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
applicant
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.applicant }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
city
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.city }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
phone
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.phone }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
email
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.email }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
gender
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.gender }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
apply_position
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.apply_position }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
born_address
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.born_address }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
bachelor_school
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.bachelor_school }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
master_school
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.master_school }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
doctor_school
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.doctor_school }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
major
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.major }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
degree
</span>
<textarea class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="{{ resume.degree }}"></textarea>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
candidate_introduction
</span>
<p class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="">{{ resume.candidate_introduction }}</p>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
work_experience
</span>
<p class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="">{{ resume.work_experience }}
</p>
</label>
</label>
<label class="relative block p-3 border-2 border-black rounded" htmlFor="name">
<span class="text-md font-semibold text-zinc-900" htmlFor="name">
project_experience
</span>
<p class="w-full bg-transparent p-0 text-sm text-gray-500 " id="name"
type="text" placeholder="">{{ resume.project_experience }}</p>
</label>
</div>
</div>
</div>
</div>
{% endblock %}
{% block footer %}
<div class="text-center p-6 bg-gray-200">
<span>? 2021 Copyright:</span>
<a class="text-gray-600 font-semibold" href="https://tailwind-elements.com/">Hogwarts</a>
</div>
{% endblock %}
- 效果
5. 添加查看簡歷詳情鏈接字段
我們在站點查看模型,展現(xiàn)的都是
list_display
引用的字段,其實不止可以引用字段,還可以引用方法
思路是根據(jù)其字段得到其簡歷,這里我們選擇hr可用于聯(lián)系的字段
phone
(電話),由于一個用戶可能投遞過多份簡歷,而這里默認展示第一份簡歷(可以優(yōu)化成ul形式或者下拉框,這里就不太深的處理了,產(chǎn)品的迭代思維,mpd(minimun product develop)產(chǎn)品思想就是快速搭建核心需求,省略大部分細枝末節(jié),先完成最核心部分,有時候在細節(jié)上處理好,會花費很多時間而導致整個項目開發(fā)緩慢)
mark_safe
是為了避免html便簽中有攻擊的代碼,所以對其進行安全檢查
from django.utils.safestring import mark_safe
@admin.register(Resume)
class ResumeAdmin(admin.ModelAdmin):
# exclude 不包括列表.隱藏字段(系統(tǒng)自定生成默認值為其值)
exclude = ('applicant',)
# 展示列表
list_display = ('id', 'username', 'applicant', 'get_resume_detail','phone', 'create_time', 'modify_time')
list_display_links = ('username',)
# obj是點擊的單個對象,queryset是選中的多個對象
def get_resume_detail(self, obj):
if not obj.phone:
return ''
resumes = Resume.objects.filter(phone=obj.phone)
if resumes:
return mark_safe('<a href="/resume/%s" target="_black">%s</a>' % (resumes.first().id, "查看簡歷詳情"))
return ''
# show_description 是同模型中 verbose_name 一樣的存在,返回在頁面顯示的字符串
get_resume_detail.short_description = '查看簡歷詳情'
# get_resume_detail.allow_tags = True
- 效果
二、優(yōu)化admin站點login頁面
1) 使用管理站點主題
往往在實際中,我們需要美化admin后臺,這時我們可以選擇django已有的主題樣式配置,并在基礎上按照需求重寫模板。
- 這里我們選擇admin后臺主題 風格相比最好看的
simpleui
主題, 安裝配置見官方文檔https://simpleui.72wo.com/docs/simpleui/QUICK.html#%E6%A8%A1%E6%9D%BF
( 官方文檔很詳細)
- 并且
simpleui
主題有一個很好的地方就是,在詳情頁的路由會被直接使用標簽整個引入整個頁面(保證了管理員在管理站點的同時進入非admin站點頁面)
2) 重寫模板
我們想要按照自己需求修改頁面,只需要在對應主題安裝包中找到對應頁面放到
templates
對應目錄即可,他會覆蓋對應文件,(原理:django
查找原理是按照當前項目優(yōu)先查找,再去安裝的應用的查找,所以此時會覆蓋原來的模板文件,注意!:此時我只需要復制想要修改頁面,不需要全部復制過來,避免到時候出現(xiàn)模板多余覆蓋)
- 這里以登錄頁面為例:
文章來源:http://www.zghlxwxcb.cn/news/detail-419317.html
參考文獻:
重寫admin站點模板
mark_safe&format_html
short_descript
allow_tags已過時,使用mark_safe保證安全文章來源地址http://www.zghlxwxcb.cn/news/detail-419317.html
??到這里,如果還有什么疑問??
??歡迎私信博主問題哦,博主會盡自己能力為你解答疑惑的!??
??如果對你有幫助,你的贊是對博主最大的支持?。??
到了這里,關于【Django | 開發(fā)】面試招聘信息網(wǎng)站(美化admin站點&添加查看簡歷詳情鏈接)的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!