使用Python Django框架制作一个音乐网站,
本篇主要是歌手页-全部歌手页功能开发。
目录
分出首页样式内容
创建首页样式文件
首页引入样式文件
全部歌手列表
创建路由
显示视图
引入分页实现库
视图方法
创建歌手首页
增加歌手跳转
导航条改活
首页增加导航条
歌手页增加导航条
歌手首字母搜索
路由增加参数
视图字母搜索
模板字母搜索
筛选无数据处理
修改歌手跳转链接
总结
把首页样式内容从基础样式文件中移动出来,独立创建index.css文件。
在idnex.html引入index.css文件,防止首页样式设置影响其他页面样式。
内容如下:
{% extends 'common/base.html' %}
{% load static %}
{% block title %}我的音乐{% endblock title %}
{% block content %}
在player/urls.py中在原有路由下增加新路由,并设置分页参数page。
path('singer/', views.singer, name='singer'),
在player/views.py中创建歌手模块首页视图方法。
from django.core.paginator import Paginator
处理字母列表这个很简单。关键在于全部歌手列表,先获取歌手列表数据,然后通过分页组件处理成分页数据,最后返回给模板。
内容如下:
def singer(request, page):
""" 歌手列表 """
# 字母列表
letters = [chr(i) for i in range(ord('A'), ord('Z') + 1)]
# 所有歌手列表
singlerList = Singler.objects.all().order_by('-singe_num')
# 实例化Paginator 每页显示24条
paginator = Paginator(singlerList, 24)
# 获取当前页码数据
res = paginator.page(page)
return render(request, 'singer/index.html', {
'letters': letters,
'singlerList': res
})
在templates中创建singer文件夹,并在文件夹中创建index.html文件。
内容如下:
{% extends 'common/base.html' %}
{% load static %}
{% block title %}我的音乐-歌手{% endblock title %}
{% block content %}
{% for item in singlerList %}
{% if forloop.counter < 6 %}
{% elif forloop.counter == 7 %}
{% else %}
{% endif %}
{% endfor %}
{% if list_num < 1 %}
暂无相关数据
{% endif %}
{% if list_num > 1 %}
{% endif %}
{% endblock content %}
修改header.html文件中歌手跳转超链接。
内容如下:
歌手
想了想还是把导航条改为每个页面,而不是作为公共部分。
基础模板中去掉导航头,并把导航条内容移动到首页原内容之上。
内容如下:
{% extends 'common/base.html' %}
{% load static %}
{% block title %}我的音乐{% endblock title %}
{% block content %}
在分类筛选列表模块之上增加导航条。
内容如下:
全部歌手列表增加首字母筛选条件,下面就开始实现。
在原有分页参数后增加字母搜索参数。
path('singer/detail//', views.singer_detail, name='singer_detail'),
增加name参数接收字母值,如果是#则获取所有歌手列表,其他字母查询相应歌手列表。
def singer(request, page, name):
""" 歌手列表 """
# 字母列表
letters = [chr(i) for i in range(ord('A'), ord('Z') + 1)]
# 是否搜索首字母
if name != '#':
# 符合首字母的歌手列表
singlerList = Singler.objects.filter(first_letter=name).order_by('-singe_num')
else:
# 所有歌手列表
singlerList = Singler.objects.all().order_by('-singe_num')
# 实例化Paginator 每页显示24条
paginator = Paginator(singlerList, 24)
# 获取当前页码数据
res = paginator.page(page)
return render(request, 'singer/index.html', {
'letters': letters,
'singlerList': res,
'list_num': len(singlerList)
})
全部歌手页链接增加字母筛选条件。