【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

这篇具有很好参考价值的文章主要介绍了【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

🤵‍♂️ 个人主页: @计算机魔术师
👨‍💻 作者简介:CSDN内容合伙人,全栈领域优质创作者。
🌐 推荐一款找工作神器网站: 宝藏网站 |笔试题库|面试经验|实习招聘内推|

该文章收录专栏
✨—【Django | 项目开发】从入门到上线 专栏—✨

一、查看简历详情

【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

由于前文所开发的简历投递,并将简历进入到面试流程,在后台中我们是只能看到其resume简历 模型candidate候选人 中相同字段信息的,关于个人能力描述,项目经验等都没有录入,此时我们希望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 %}



  • 效果
    【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

5. 添加查看简历详情链接字段

我们在站点查看模型,展现的都是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
  • 效果
    【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

二、优化admin站点login页面

1) 使用管理站点主题

往往在实际中,我们需要美化admin后台,这时我们可以选择django已有的主题样式配置,并在基础上按照需求重写模板。

  • 这里我们选择admin后台主题 风格相比最好看的simpleui主题, 安装配置见官方文档
    https://simpleui.72wo.com/docs/simpleui/QUICK.html#%E6%A8%A1%E6%9D%BF ( 官方文档很详细)

【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

  • 并且simpleui主题有一个很好的地方就是,在详情页的路由会被直接使用标签整个引入整个页面保证了管理员在管理站点的同时进入非admin站点页面

【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

2) 重写模板

我们想要按照自己需求修改页面,只需要在对应主题安装包中找到对应页面放到templates对应目录即可,他会覆盖对应文件,(原理:django 查找原理是按照当前项目优先查找,再去安装的应用的查找,所以此时会覆盖原来的模板文件,注意!:此时我只需要复制想要修改页面,不需要全部复制过来,避免到时候出现模板多余覆盖)

  • 这里以登录页面为例:

【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)

参考文献:
重写admin站点模板
mark_safe&format_html
short_descript
allow_tags已过时,使用mark_safe保证安全文章来源地址https://www.toymoban.com/news/detail-419317.html

			        🤞到这里,如果还有什么疑问🤞
		🎩欢迎私信博主问题哦,博主会尽自己能力为你解答疑惑的!🎩
			🥳如果对你有帮助,你的赞是对博主最大的支持!!🥳

到了这里,关于【Django | 开发】面试招聘信息网站(美化admin站点&添加查看简历详情链接)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Django】招聘面试管理01 创建项目&运行项目

    跟着视频学一学,记录一下。 照着步骤创建虚拟环境,安装Django等依赖包,创建项目:【Django学习】01 项目创建、结构及命令 项目结构: 访问网页( 127.0.0.1:8000 或 指定IP:8000 ),可以看到Django的初始页面: 项目运行之后,Django使用默认的SQLite数据库,会在项目的根目录下

    2024年02月13日
    浏览(40)
  • 基于招聘网站的大数据专业相关招聘信息建模与可视化分析

    需要本项目的可以私信博主!!! 在大数据时代背景下,数据积累导致大数据行业的人才需求快速上升,大量的招聘信息被发布在招聘平台上。深入研究这些信息能帮助相关人士更好地理解行业动态,并对其未来发展进行预测。本文主要通过分析51job网站上的大数据职位招聘

    2024年02月09日
    浏览(40)
  • 【爬虫系列】使用Selenium模块采集招聘网站的职位信息(1)

    在上篇演示使用了 Request 模块采集智联招聘网站 PC 端网页的招聘信息,结果遇到了比较隐蔽的反爬限制(当时还不清楚什么原因导致的),看来使用该模块这条路暂时走不通了, 打算换用 Selenium 模块试试,并尝试寻找该网站反爬限制的具体原因 。 一、环境准备 Google 浏览

    2024年02月20日
    浏览(54)
  • 【爬虫系列】Python爬虫实战--招聘网站的职位信息爬取

    1. 需求分析 从网上找工作,大家一般都会通过各种招聘网站去检索相关信息,今天利用爬虫采集招聘网站的职位信息,比如岗位名称,岗位要求,薪资,公司名称,公司规模,公司位置,福利待遇等最为关心的内容。在采集和解析完成后,使用 Excel 或 csv 文件保存。 2. 目标

    2024年02月02日
    浏览(48)
  • 基于python爬虫技术的岗位招聘信息采集系统的设计与实现(Django框架)

     博主介绍 :黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育和辅导。 所有项目都配有从入门到精通的基础知识视频课程,免费 项目配有对应开发文档、开题报告、任务书、

    2024年02月02日
    浏览(41)
  • 基于Python的招聘网站信息爬取与数据分析

    文末获取资源,收藏关注不迷路 随着社会经济的快速发展,人们的生活水平得到了显著提高,但随之而来的社会问题也越来越多。其中最为显著的就是就业问题。为此,招聘信息的展示也变得越来越为重要。但是在大量的招聘信息中,人们在提取自己最想要的信息时变得不那

    2024年02月04日
    浏览(47)
  • 基于Python的51job(前程无忧)招聘网站数据采集,通过selenium绕过网站反爬,可以采集全国各地数十万条招聘信息

    使用Python编程语言和Selenium库来实现自动化的网页操作,从而实现登录、搜索和爬取职位信息的功能。 首先,导入了所需的库,包括time用于处理时间,selenium用于模拟浏览器操作,csv用于写入CSV文件,BeautifulSoup用于解析网页数据。然后,定义了一个名为login的函数,该函数接

    2024年01月19日
    浏览(58)
  • 基于python重庆招聘信息数据可视化分析全屏大屏系统设计与实现(django框架)

     博主介绍 :黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育和辅导。 所有项目都配有从入门到精通的基础知识视频课程,免费 项目配有对应开发文档、开题报告、任务书、

    2024年02月04日
    浏览(43)
  • 基于python四川成都招聘信息数据可视化分析全屏大屏系统设计与实现(django框架)

     博主介绍 :黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育和辅导。 所有项目都配有从入门到精通的基础知识视频课程,免费 项目配有对应开发文档、开题报告、任务书、

    2024年02月04日
    浏览(48)
  • 程序员岗位招聘信息数据可视化分析全屏大屏系统设计与实现(python的django框架)

     博主介绍 :黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育和辅导。 所有项目都配有从入门到精通的基础知识视频课程,免费 项目配有对应开发文档、开题报告、任务书、

    2024年02月05日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包