当前位置: 首页 > news >正文

Django实现音乐网站 (21)

使用Python Django框架做一个音乐网站,

本篇音乐播放器功能完善及原有功能修改。

目录

播放列表修改

视图修改

删除、清空播放器

设置路由

视图处理

修改加载播放器脚本

模板修改

脚本设置

清空功能实现

删除列表音乐

播放列表无数据处理

视图修改

播放音乐与列表同步

修改设置播放效果

监听媒体播放事件

歌单、专辑、单曲列表播放

音乐播放设置

添加单曲处理

总结


播放列表修改

原来的播放列表只是查询所有歌曲,改为从添加的播放列表中调用数据。

视图修改

只需要查询播放器表所有记录,之后通过单曲、歌手外键查询其他需要信息。

def play_list(request):""" 音乐播放器列表 """mp3_list = Player.objects.all()arr = []for item in mp3_list:arr.append({'id': item.id,'cover': str(item.singler.portrait),'singer': item.singler.name,'singer_id': item.singler_id,'song_id': item.singe.id,'song_name': item.singe.name,'song_path': str(item.singe.path),'duration': get_song_duration(int(item.singe.duration)),})return JsonResponse({'list': arr})

删除、清空播放器

设置路由

# 删除或清空播放器
path('clear_player', views.clear_player, name='clear_player'),

视图处理

清空播放列表和删除播放列表中某个单曲在一个视图处理可通过type来判断。

def clear_player(request):""" 删除或清空播放器列表 """id = request.GET.get('id')type = request.GET.get('type')if type == '1':# 播放器删除单曲Player.objects.filter(pk=id).delete()else:# 清空所有歌曲Player.objects.all().delete()res = {'status': 1, 'msg': '操作成功!'}return JsonResponse(res)

修改加载播放器脚本

加载播放器方法从匿名方法改为设置方法,以方便其他地方调用。

修改内容如下:

模板修改

脚本设置

在base.html最下面设置js脚本请求视图;操作成功后,重新加载音乐播放器。

// 清空播放列表
function clear_player(id, type) {$. get("/clear_player", {'id':id, 'type':type}, function (msg) {if(msg.status == 1) {layer.msg(msg.msg, {icon: 6});onPlayer();} else {layer.msg(msg.msg, {icon: 5});}});
}

清空功能实现

播放器音乐列表清空列表元素增加调用清空列表方法。

内容如下:

<div class="list_top flex_c"><div id="play_title"></div><div class="flex_c"><div class="clear_all" onclick="clear_player(0, 2)"><i class="glyphicon glyphicon-trash"></i><span class="clear_btn">清空列表</span></div><i class="close glyphicon glyphicon-remove"></i></div>
</div>

删除列表音乐

在音乐播放器列表增加调用删除单曲方法,需要修改play.js中渲染音乐播放器列表处理。

内容如下:

'<i title="删除歌曲" class="glyphicon glyphicon-trash" onclick="clear_player('+ music_list[i].id +', 1)"></i>&nbsp;&nbsp;' +

播放列表无数据处理

当清空播放列表后,渲染出错。

视图修改

在播放列表视图中增加无数据情况的数据返回。

def play_list(request):""" 音乐播放器列表 """mp3_list = Player.objects.all()arr = []if mp3_list:for item in mp3_list:arr.append({'id': item.id,'cover': '/media/' + str(item.singler.portrait),'singer': item.singler.name,'singer_id': item.singler_id,'song_id': item.singe.id,'song_name': item.singe.name,'song_path': '/media/' + str(item.singe.path),'duration': get_song_duration(int(item.singe.duration)),})else:arr.append({'id': 0,'cover': '/static/images/s2.jpg','singer': '无歌手','singer_id': 0,'song_id': 0,'song_name': '无歌曲','song_path': '','duration': '0:00',})return JsonResponse({'list': arr})

播放音乐与列表同步

在歌单、专辑或者单曲列表点击播放图标进行播放音乐时列表状态同步。

修改设置播放效果

修改play.js中设置音乐播放器列表效果的代码,设置id选择器。

内容如下:

// 设置音乐播放器列表
function set_media_list(music_list) {var play_html = '';for (var i = 0; i < music_list.length; i++) {if (i) {play_html += '<div class="flex_c list_item"  id="music_num'+ (i + 1) +'" style="pointer-events: auto;">' +'<div class="list_idx">' + (i + 1) +'<span class="playing" style="display: none">';} else {play_html += '<div class="flex_c list_item active_cur" id="music_num'+ (i + 1) +'" style="pointer-events: auto;">' +'<div class="list_idx">' + (i + 1) + '' +'<span class="playing">';}

监听媒体播放事件

在原有加载播放器事件中增加监听媒体播放事件处理,在这里处理同步音乐播放和列表状态。

内容如下:

// 监听播放器 播放时触发
$player.addEventListener('play', function () {$("#music_num"+currentIndex).removeClass('active_cur');$("#music_num"+currentIndex).find('.playing').hide();$("#music_num"+(currentIndex+1)).addClass('active_cur');$("#music_num"+(currentIndex+1)).find('.playing').show();
});

效果:

歌单、专辑、单曲列表播放

需要修改设置音乐播放器的脚本的方法和增加对播放操作的事件处理。

要到达的效果为:在歌单、专辑的单曲列表点击全部播放则添加所有单曲并播放第一个歌曲;

而在单曲列表中点击单曲的播放则增加当前单曲到播放列表并播放当前单曲。

音乐播放设置

增加对musicPlay类的点击事件响应处理,

获取按钮上的id和type,来进行单曲、歌单、专辑分别添加处理;

之后设置当前播放音乐显示和路径处理,播放列表显示处理,

音乐播放器播放状态并进行播放。

$('.musicPlay').click(function() {var music_dian = $('#music_dian');var id = $(this).attr('data-id');var type = $(this).attr('data-type');var nowNum = 0;if(type == 2) {// 歌单var urll = '/songsheet_player';} else if(type == 3) {// 专辑var urll = '/album_player';} else {// 单曲var urll = '/add_player';}$. get(urll, {'id':id}, function (msg) {if(msg.status == 1) {layer.msg(msg.msg, {icon: 6});setInit();} else {layer.msg(msg.msg, {icon: 5});}});if(type == 1) {var nowNum = music_list.length - 1;}// 设置当前播放音乐currentIndex = nowNum;setMusic();// 同步播放列表状态var nowDiv = $("#play_list").children('.active_cur');nowDiv.find('.playing').hide();nowDiv.removeClass('active_cur');var newDiv = $("#music_num"+(nowNum+1));newDiv.addClass('active_cur');newDiv.find('.playing').show();// 设置播放器 播放状态if (music_dian.attr('class') == 'glyphicon glyphicon-play') {music_dian.attr('class', 'glyphicon glyphicon-pause');}$player.play();
});

添加单曲处理

视图中添加单曲音乐时,重复的单曲不再添加进入单曲中。

def add_player(request):""" 添加歌曲到播放器 """# 查询相应单曲id = request.GET.get('id')info = Singe.objects.filter(pk=id).first()repeat = Player.objects.filter(singe=id).first()if repeat:return JsonResponse({'status': 1, 'msg': '添加“%s”成功!' % info.name})if info:# 加入到播放列表中singerDb = Singler.objects.filter(id=info.singler_id).first()# 新增单曲playDb = Player()playDb.name = info.name# 建立关联playDb.singe = infoplayDb.singler = singerDbplayDb.save()res = {'status': 1, 'msg': '添加“%s”成功!' % info.name}else:res = {'status': 0, 'msg': '该歌曲不存在,无法添加!'}return JsonResponse(res)

总结

本篇内容为音乐播放器表创建后的列表渲染,删除清空播放器功能;

播放音乐列表同步,添加播放音乐等功能实现。

相关文章:

Django实现音乐网站 (21)

使用Python Django框架做一个音乐网站&#xff0c; 本篇音乐播放器功能完善及原有功能修改。 目录 播放列表修改 视图修改 删除、清空播放器 设置路由 视图处理 修改加载播放器脚本 模板修改 脚本设置 清空功能实现 删除列表音乐 播放列表无数据处理 视图修改 播放…...

LeetCode 面试题 10.11. 峰与谷

文章目录 一、题目二、C# 题解 一、题目 在一个整数数组中&#xff0c;“峰”是大于或等于相邻整数的元素&#xff0c;相应地&#xff0c;“谷”是小于或等于相邻整数的元素。例如&#xff0c;在数组{5, 8, 4, 2, 3, 4, 6}中&#xff0c;{8, 6}是峰&#xff0c; {5, 2}是谷。现…...

【专题】测试人员为什么需要学会做业务总结?

背景 如何回答以下这个问题的知识支撑&#xff1a;系统的测试重点在哪&#xff0c;难点是什么&#xff0c;怎么攻克&#xff0c;为什么要这样设计&#xff1f;项目交接效率&#xff1f; 同样是做业务测试&#xff0c;为什么有的人是A有的人只能C 二、框架 2.1 测试场景 重点…...

uni-app:实现当前时间的获取,并且根据当前时间判断所在时间段为早上,下午还是晚上

效果图 核心代码 获取当前时间 toString()方法将数字转换为字符串 padStart(2, 0)&#xff1a;padStart()方法用于在字符串头部填充指定的字符&#xff0c;使其达到指定的长度。该方法接受两个参数&#xff1a;第一个参数为期望得到的字符串长度&#xff0c;第二个参数为要填充…...

C# .Net6 指定WSDL, 生成Webservice,调用该接口服务

C# .Net6 指定WSDL, 调用该接口服务。 IDE&#xff1a; Microsoft Visual Studio Community 2022 (64 位)平台&#xff1a;.Net6协议&#xff1a;Soap协议 Xml格式 功能 需要开发一个前置机程序&#xff0c; 用于和硬件程序交互&#xff0c;已知条件是&#xff1a;嵌入式同事…...

JS基本小知识:函数

目录 函数的基本概念 函数的定义和调用 函数的定义 函数的调用 函数的参数和返回值 参数的作用域和生命周期 返回值的作用和使用场景 匿名函数和箭头函数 匿名函数 本文将介绍 JavaScript 中的一个知识点&#xff1a;函数。函数是 JavaScript 中非常重要的一个概念&am…...

在Windows下Edge浏览器OA发起流程问题

在Edge浏览器中发起流程 如上图所示&#xff0c;不能正常打开Excel&#xff0c;自动将Excel表格转为了PDF 怎么处理&#xff1f;还得使用IE浏览器来访问&#xff0c;但打开IE后又自动跳转到Edge&#xff0c;根本就不给使用&#xff0c;在Edge下使用IE模式也解决不了这个问题。…...

2020年亚太杯APMCM数学建模大赛A题激光标记舱口轮廓生成求解全过程文档及程序

2020年亚太杯APMCM数学建模大赛 A题 激光标记舱口轮廓生成 原题再现&#xff1a; 激光是20中的一项重要发明世纪&#xff0c;它被称为“最锋利的刀”、“最精确的尺子”和“最不寻常的光”。 激光已越来越多地应用于工业加工&#xff0c; 其中可以是就业在各种加工业务例如作…...

【单元测试】--工具与环境

一、单元测试工具概览 1.1 JUnit JUnit 是一个广泛用于 Java 程序开发的开源测试框架。它是单元测试的标准工具之一&#xff0c;用于编写和运行测试用例&#xff0c;以确保 Java 程序的各个组件按预期工作。以下是一些关键特点和概念&#xff0c;来介绍 JUnit&#xff1a; 注…...

基于Java的汽车维修预约管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09; 代码参考数据库参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&am…...

vscode调试container(进行rocksdb调试)+vscode比较git项目不同分支和fork的哪个分支

vscode调试container&#xff08;进行rocksdb调试&#xff09; 参考链接&#xff1a; https://blog.csdn.net/qq_29809823/article/details/128445308#t5 https://blog.csdn.net/qq_29809823/article/details/121978762#t7 使用vscode中的插件dev containners->点击左侧的…...

[python-大语言模型]从浅到深一系列学习笔记记录

整体学习路径参照&#xff1a;点这里 python-机器学习-深度学习-大语言模型-数据开发 面向开发者的LLM入门提示原则 面向开发者的LLM入门 学习链接&#xff1a; github地址&#xff1a;https://github.com/datawhalechina/prompt-engineering-for-developers 在线阅读地址&…...

Android 指定有线网或Wifi进行网络请求

Android 指定有线网或Wifi进行网络请求 文章目录 Android 指定有线网或Wifi进行网络请求一、前言&#xff1a;二、指定网络通讯测试1、 窗口命令 ping -I 网络节点 IP2、Java 代码指定特定网络通讯 三、指定特定网络的demo app 开发1、效果图&#xff1a;2、实际测试结果说明&a…...

消除过期的对象引用

Java虽然有自己的垃圾回收机制,但是并没有那么的智能,对于被引用的对象,就算我们已经不在使用它了,但是Java的回收机制是不会回收它们的,人们称之为“内存泄漏”。 以下为三种不同的内存泄漏场景,极其优化方案 1、只要类自己管理内存,就该警惕内存泄漏问题 例如Stack…...

【Shell】环境变量 自定义变量 特殊变量

Shell变量&#xff1a;环境变量 目标 1、理解什么是系统环境变量&#xff1f; 2、掌握常用的系统环境变量都有哪些&#xff1f; Shell变量的介绍 变量用于存储管理临时的数据, 这些数据都是在运行内存中的. 变量类型 系统环境变量 自定义变量 特殊符号变量 系统环境变…...

Maven 打包 jar、war 包配置

1、导出 jar 包配置 <build><finalName>weaver-customerservice-distribution-component</finalName><resources><resource><directory>src/main/java</directory><includes><include>**/*.xml</include></inc…...

感悟:一个小小的摄像头APP,也解决了很多BUG

本来以为&#xff0c;简单的测试一下就行了&#xff0c;应该没有几个BUG。应该是比较轻松的。 然而现实是每天干活时&#xff0c;都能发现几个BUG。这BUG不解决还不行。六石管理学告诉我们四大容易&#xff1a;说容易&#xff0c;看容易&#xff0c;看别人容易&#xff0c;会了…...

顺序表第三节(通讯录基础版)

目录 可以先看一遍第二节在看这个 顺序表&#xff08;第二节&#xff09;实现和解析-CSDN博客 1.顺序表的头文件 2.初始化通讯录 3.添加通讯录 特殊&#xff1a;查找对应姓名的通讯录的序号 4.删除通讯录 5.展示通讯录 6.查找通讯录 7.修改通讯录 8.销毁通讯…...

数字ID和字符串ID互相转化

对于想隐藏真实id的需求&#xff0c;比如想加密userId等 使用示例&#xff1a; * 不指定长度* AlphaIDCustom(12354&#xff09;&#xff1b; //会将数字转换为字母。* AlphaIDCustom(PpQXn7COf,true&#xff09;&#xff1b;//会将字母ID转换为对应的数字。* 指定长度* Alpha…...

「Qt中文教程指南」如何创建基于Qt Widget的应用程序(三)

Qt 是目前最先进、最完整的跨平台C开发工具。它不仅完全实现了一次编写&#xff0c;所有平台无差别运行&#xff0c;更提供了几乎所有开发过程中需要用到的工具。如今&#xff0c;Qt已被运用于超过70个行业、数千家企业&#xff0c;支持数百万设备及应用。 本文描述了如何使用…...

C++初阶-list的底层

目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...

简易版抽奖活动的设计技术方案

1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

ssc377d修改flash分区大小

1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...

YSYX学习记录(八)

C语言&#xff0c;练习0&#xff1a; 先创建一个文件夹&#xff0c;我用的是物理机&#xff1a; 安装build-essential 练习1&#xff1a; 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件&#xff0c;随机修改或删除一部分&#xff0c;之后…...

Swagger和OpenApi的前世今生

Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章&#xff0c;二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑&#xff1a; &#x1f504; 一、起源与初创期&#xff1a;Swagger的诞生&#xff08;2010-2014&#xff09; 核心…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)

Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败&#xff0c;具体原因是客户端发送了密码认证请求&#xff0c;但Redis服务器未设置密码 1.为Redis设置密码&#xff08;匹配客户端配置&#xff09; 步骤&#xff1a; 1&#xff09;.修…...

音视频——I2S 协议详解

I2S 协议详解 I2S (Inter-IC Sound) 协议是一种串行总线协议&#xff0c;专门用于在数字音频设备之间传输数字音频数据。它由飞利浦&#xff08;Philips&#xff09;公司开发&#xff0c;以其简单、高效和广泛的兼容性而闻名。 1. 信号线 I2S 协议通常使用三根或四根信号线&a…...

BLEU评分:机器翻译质量评估的黄金标准

BLEU评分&#xff1a;机器翻译质量评估的黄金标准 1. 引言 在自然语言处理(NLP)领域&#xff0c;衡量一个机器翻译模型的性能至关重要。BLEU (Bilingual Evaluation Understudy) 作为一种自动化评估指标&#xff0c;自2002年由IBM的Kishore Papineni等人提出以来&#xff0c;…...

「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案

在移动互联网营销竞争白热化的当下&#xff0c;推客小程序系统凭借其裂变传播、精准营销等特性&#xff0c;成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径&#xff0c;助力开发者打造具有市场竞争力的营销工具。​ 一、系统核心功能架构&…...

Xela矩阵三轴触觉传感器的工作原理解析与应用场景

Xela矩阵三轴触觉传感器通过先进技术模拟人类触觉感知&#xff0c;帮助设备实现精确的力测量与位移监测。其核心功能基于磁性三维力测量与空间位移测量&#xff0c;能够捕捉多维触觉信息。该传感器的设计不仅提升了触觉感知的精度&#xff0c;还为机器人、医疗设备和制造业的智…...