当前位置:  首页>> 技术小册>> Django快速开发实战

第七章 职位管理系统:添加自定义页面:让匿名用户可以浏览职位列表页

在开发一个完整的职位管理系统时,确保不同用户群体(包括匿名用户)能够访问系统提供的信息是至关重要的。本章将详细介绍如何在Django项目中创建一个允许匿名用户浏览职位列表的自定义页面。我们将从设计思路、模型定义、视图编写、模板创建以及URL配置等几个方面展开说明。

7.1 设计思路

在设计职位列表页之前,首先需要明确几个关键点:

  1. 数据模型:确保已有一个合适的职位(Job)模型,用于存储职位信息,如职位名称、职位描述、工作地点、薪资范围等。
  2. 用户权限:本章节的重点是让匿名用户(即未登录的用户)也能访问职位列表页。这通常意味着不需要在视图中进行用户认证检查。
  3. 页面布局与功能:职位列表页应清晰展示所有职位的基本信息,并提供链接或按钮以便用户进一步操作(如查看详情、申请职位等)。
  4. 分页处理:考虑到职位数量可能较多,实现分页功能以提升用户体验。

7.2 数据模型定义

假设我们已经有了如下的职位模型(models.py):

  1. from django.db import models
  2. class Job(models.Model):
  3. title = models.CharField(max_length=200, verbose_name="职位名称")
  4. description = models.TextField(verbose_name="职位描述")
  5. location = models.CharField(max_length=100, verbose_name="工作地点")
  6. salary_range = models.CharField(max_length=100, verbose_name="薪资范围")
  7. is_active = models.BooleanField(default=True, verbose_name="是否激活")
  8. def __str__(self):
  9. return self.title
  10. class Meta:
  11. verbose_name = "职位"
  12. verbose_name_plural = "职位"

7.3 视图编写

接下来,我们需要编写一个视图来处理职位列表的展示。由于此页面面向匿名用户开放,我们可以在视图中直接查询所有激活状态的职位。

  1. from django.shortcuts import render
  2. from .models import Job
  3. from django.core.paginator import Paginator
  4. def job_list(request):
  5. # 查询所有激活状态的职位
  6. jobs = Job.objects.filter(is_active=True).order_by('-id') # 假设以创建时间降序排列
  7. # 分页处理
  8. paginator = Paginator(jobs, 10) # 每页显示10个职位
  9. page_number = request.GET.get('page')
  10. page_obj = paginator.get_page(page_number)
  11. context = {
  12. 'jobs': page_obj,
  13. }
  14. return render(request, 'jobs/job_list.html', context)

7.4 模板创建

现在,我们需要为职位列表页创建一个模板(job_list.html),该模板将展示从视图中传递过来的职位信息。

  1. <!-- templates/jobs/job_list.html -->
  2. {% extends 'base.html' %}
  3. {% block content %}
  4. <h1>职位列表</h1>
  5. {% if jobs %}
  6. <ul>
  7. {% for job in jobs %}
  8. <li>
  9. <h2>{{ job.title }}</h2>
  10. <p>{{ job.description|truncatechars:100 }}</p>
  11. <p>工作地点: {{ job.location }}</p>
  12. <p>薪资范围: {{ job.salary_range }}</p>
  13. <a href="{% url 'job_detail' job.id %}">查看详情</a>
  14. </li>
  15. {% endfor %}
  16. </ul>
  17. {% if jobs.has_other_pages %}
  18. <div class="pagination">
  19. <span class="page-links">
  20. {% if jobs.has_previous %}
  21. <a href="?page=1">&laquo; 首页</a>
  22. <a href="?page={{ jobs.previous_page_number }}">上一页</a>
  23. {% endif %}
  24. <span class="page-current">
  25. Page {{ jobs.number }} of {{ jobs.paginator.num_pages }}.
  26. </span>
  27. {% if jobs.has_next %}
  28. <a href="?page={{ jobs.next_page_number }}">下一页</a>
  29. <a href="?page={{ jobs.paginator.num_pages }}">末页 &raquo;</a>
  30. {% endif %}
  31. </span>
  32. </div>
  33. {% endif %}
  34. {% else %}
  35. <p>当前没有激活的职位。</p>
  36. {% endif %}
  37. {% endblock %}

注意:这里假设你已经有了一个基础的模板base.html,用于包含所有页面的共同元素(如头部、尾部等)。同时,模板中使用了truncatechars模板过滤器来限制职位描述的长度,以及分页链接的生成。

7.5 URL配置

最后,我们需要在项目的URL配置文件中添加一条规则,以便将HTTP请求映射到job_list视图。

  1. # urls.py
  2. from django.urls import path
  3. from .views import job_list
  4. urlpatterns = [
  5. # 其他URL配置...
  6. path('jobs/', job_list, name='job_list'),
  7. # 假设还需要一个职位详情页,可以这样配置
  8. path('jobs/<int:id>/', job_detail, name='job_detail'), # 假设job_detail是另一个视图函数
  9. ]

7.6 总结

通过本章的学习,我们成功地为职位管理系统添加了一个允许匿名用户浏览职位列表的自定义页面。从设计思路到实际编码,我们涵盖了数据模型定义、视图编写、模板创建以及URL配置等关键环节。这个页面的实现不仅提升了系统的可用性,也为后续的用户交互和功能扩展打下了坚实的基础。

在未来的章节中,我们将继续探索如何为不同用户群体(如注册用户、管理员等)提供更丰富的功能和更精细的权限控制,进一步完善职位管理系统。


该分类下的相关小册推荐: