
🤵♂️ 个人主页: @计算机魔术师
👨💻 作者简介:CSDN内容合伙人,全栈领域优质创作者。
🌐 推荐一款找工作神器网站: 宝藏网站 |笔试题库|面试经验|实习招聘内推|
该文章收录专栏
✨—【Django | 项目开发】从入门到上线 专栏—✨
文章目录

由于前文所开发的简历投递,并将简历进入到面试流程,在后台中我们是只能看到其
resume简历 模型与candidate候选人中相同字段信息的,关于个人能力描述,项目经验等都没有录入,此时我们希望hr能够看到完整简历
class ResumeDetailView(DetailView):
"""显示简历详情"""
model = Resume
template_name = 'resume_detail.html'
context_object_name = 'resume'
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')
]
{% 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 %}

我们在站点查看模型,展现的都是
list_display引用的字段,其实不止可以引用字段,还可以引用方法
思路是根据其字段得到其简历,这里我们选择hr可用于联系的字段
phone(电话),由于一个用户可能投递过多份简历,而这里默认展示第一份简历(可以优化成ul形式或者下拉框,这里就不太深的处理了,产品的迭代思维,mpd(minimun product develop)产品思想就是快速搭建核心需求,省略大部分细枝末节,先完成最核心部分,有时候在细节上处理好,会花费很多时间而导致整个项目开发缓慢)
mark_safe 是为了避免html便签中有攻击的代码,所以对其进行安全检查
from django.utils.safestring import mark_safe
@admin.register(Resume)
class ResumeAdmin(admin.ModelAdmin):
# exclude 不包括列表.隐藏字段(系统自定生成默认值为其值)
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

往往在实际中,我们需要美化admin后台,这时我们可以选择django已有的主题样式配置,并在基础上按照需求重写模板。
simpleui主题, 安装配置见官方文档https://simpleui.72wo.com/docs/simpleui/QUICK.html#%E6%A8%A1%E6%9D%BF ( 官方文档很详细)

simpleui主题有一个很好的地方就是,在详情页的路由会被直接使用标签整个引入整个页面(保证了管理员在管理站点的同时进入非admin站点页面)
我们想要按照自己需求修改页面,只需要在对应主题安装包中找到对应页面放到
templates对应目录即可,他会覆盖对应文件,(原理:django查找原理是按照当前项目优先查找,再去安装的应用的查找,所以此时会覆盖原来的模板文件,注意!:此时我只需要复制想要修改页面,不需要全部复制过来,避免到时候出现模板多余覆盖)

参考文献:
重写admin站点模板
mark_safe&format_html
short_descript
allow_tags已过时,使用mark_safe保证安全
🤞到这里,如果还有什么疑问🤞
🎩欢迎私信博主问题哦,博主会尽自己能力为你解答疑惑的!🎩
🥳如果对你有帮助,你的赞是对博主最大的支持!!🥳
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server