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

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

文章目录

一、查看简历详情

图片.png

由于前文所开发的简历投递,并将简历进入到面试流程,在后台中我们是只能看到其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 %}
  • 效果图片.png

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
  • 效果图片.png

二、优化admin站点login页面

1) 使用管理站点主题

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

图片.png

图片.png

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

图片.png

2) 重写模板

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

  • 这里以登录页面为例:

图片.png

参考文献:

重写admin站点模板

mark_safe&format_html

short_descript

allow_tags已过时,使用mark_safe保证安全

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



相关文章
|
2月前
|
Shell 数据库 网络架构
Django+DRF 实战:从异常捕获到自定义错误信息(下)
本文详解了 Django REST Framework 中 ValidationError 的验证流程与优先级,涵盖字段内置验证、自定义验证方法、对象级验证及数据库约束,并通过实战演示如何自定义异常提示信息。
95 1
Django+DRF 实战:从异常捕获到自定义错误信息(下)
|
2月前
|
存储 前端开发 应用服务中间件
Django 实战:静态文件与媒体文件从开发配置到生产部署
Django项目中,静态文件(Static Files)和媒体文件(Media Files)是两类不同用途的文件。本文详细介绍了它们的区别、配置方法以及在开发与生产环境中的处理方式,并结合用户头像上传功能进行实战演示,最后讲解了如何通过Nginx或OpenResty部署静态与媒体文件服务。
124 1
|
2月前
|
数据安全/隐私保护 网络架构 UED
Django+DRF 实战:从异常捕获到自定义错误信息
本文介绍了DRF(Django REST framework)中的异常处理机制,重点讲解了内置异常类ValidationError的使用场景与示例。同时通过用户注册功能的实战演示,展示了如何在序列化器中自定义参数校验规则,并在视图中捕获并返回结构化的错误信息,提升接口的健壮性与用户体验。
62 0
|
4月前
|
数据安全/隐私保护 开发者 UED
CodeBuddy 开发者福音!在线简历0元搞定,再也不怕面试翻车!
本文介绍如何用CodeBuddy和Edgeone Page MCP制作高质量在线简历,告别传统简历的局限。通过CodeBuddy生成简历工具,支持高亮亮点、添加链接与代码仓库;借助Edgeone Page MCP一键发布,实现访问控制与实时更新。该方案不依赖Word/PDF,支持技术项目展示,响应式布局适配多设备,为开发者打造专业“技术名片”。立即尝试,让HR第一眼记住你!
|
6月前
|
机器学习/深度学习 人工智能 JSON
Resume Matcher:增加面试机会!开源AI简历优化工具,一键解析简历和职位描述并优化
Resume Matcher 是一款开源AI简历优化工具,通过解析简历和职位描述,提取关键词并计算文本相似性,帮助求职者优化简历内容,提升通过自动化筛选系统(ATS)的概率,增加面试机会。
608 18
Resume Matcher:增加面试机会!开源AI简历优化工具,一键解析简历和职位描述并优化
|
6月前
|
人工智能 搜索推荐 数据处理
简历诊断与面试指导:学校用AI开出“数字处方”,生成式人工智能(GAI)认证助力学生求职
本文探讨了人工智能(AI)技术在教育领域的应用,特别是学校如何利用AI进行简历诊断与面试指导,帮助学生提升求职竞争力。同时,生成式人工智能(GAI)认证的引入填补了技能认证空白,为学生职业发展提供权威背书。AI的个性化服务与GAI认证的权威性相辅相成,助力学生在数字化时代更好地应对求职挑战,实现职业目标。文章还展望了AI技术与GAI认证在未来持续推动学生成长的重要作用。
|
10月前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
391 67
|
10月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
604 45
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
10月前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?

热门文章

最新文章