微信小程序之网易云音乐小案例

这篇具有很好参考价值的文章主要介绍了微信小程序之网易云音乐小案例。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一.编写对网易云音乐api发起请求的代码

二.编写视频项(组件)

三.编写mv列表:包含(轮播图+视频列表[每个视频项引用组件来呈现])

四.编写视频详情页


成品图:

微信小程序之网易云音乐小案例微信小程序之网易云音乐小案例

准备工作:

——在pages下新建两个page(index,video_detail)mv首页和视频详情

微信小程序之网易云音乐小案例

——在根目录下创建components,并在其中创建一个component(video-item)视频项

微信小程序之网易云音乐小案例

——在根目录下创建service,并在其中创建api_video.js和index.js,用于对api发起请求

微信小程序之网易云音乐小案例

——在utils下创建format.wxs,用于数据格式的转换【下附format的代码】

微信小程序之网易云音乐小案例

//数据处理
function formatCount(count){
  var counter = parseInt(count)
  if(counter > 100000000){
    return (counter / 100000000).toFixed(1) + "亿"
  }else if(counter > 10000){
    return (counter / 10000).toFixed(1) + "万"
  }else {
    return counter + ""
  }
}
//往左边加零
function padLeftZero(time){
  time = time + ""
  //先在前面加两个0,然后从字符串长度位开始截取
  return ("00" + time).slice(time.length)
}
//时间转换
function formatDuration(duration)
{
  //转成秒数
  duration = duration / 1000
  //取整数部分,除以60得到分钟数
  var minute = Math.floor(duration / 60)
  //取余数部分的秒数
  var second = Math.floor(duration % 60)

  return padLeftZero(minute) + ":" + padLeftZero(second) 
}
module.exports = {
  formatCount:formatCount,
  formatDuration:formatDuration
}

 ——在根目录下创建images,并在其中创建bannar,用于轮播图的展示【下附图片】

微信小程序之网易云音乐小案例

微信小程序之网易云音乐小案例微信小程序之网易云音乐小案例微信小程序之网易云音乐小案例微信小程序之网易云音乐小案例微信小程序之网易云音乐小案例微信小程序之网易云音乐小案例微信小程序之网易云音乐小案例

一.编写对网易云音乐api发起请求的代码

①service/index.js

const BASE_URL = "https://autumnfish.cn" //网易云音乐api接口,如果接口失效了,可以百度重新搜索一个进行替换,或者在本地开一个api服务器也行.
//创建一个类,赋予它请求接口的方式
class MusicRequest{
 request(url,method,params){
    return new Promise((resolve,reject)=>{
      wx.request({
        url: BASE_URL+url,
        data:params,
        method:method,
        success:res=>resolve(res.data),
        fail:err=>reject(err)
      })
    })
  }
   get(url,params){
    return this.request(url,"GET",params)
  }
   post(url,params){
    return this.request(url,"POST",params)
  }
}
//向外抛出一个对象
export default new MusicRequest();

②service/api_video.js

import musicRequest from './index';

//获取热门视频
export function getTopMV(offset,limit=10){
  return musicRequest.get("/top/mv",{offset,limit})
}

//获取视频地址
export function getMVURL(id){
  return musicRequest.get("/mv/url",{id})
}

//获取视频详情信息
export function getMVDetail(id){
  return musicRequest.get("/mv/detail",{mvid:id})
}

//获取其他相关的视频
export function getRelatedVideo(id){
  return musicRequest.get("/related/allvideo",{id})
}

二.编写视频项(组件)

①components/video-item/index.wxml

<!--components/video-item/index.wxml-->
<wxs src="../../utils/format.wxs" module="format"/>
<view class="item">
  <view class="album">
    <image class="image" src="{{item.cover}}" mode="widthFix" />
    <view class="info">
      <view class="count">
        {{format.formatCount(item.playCount)}}
      </view>
      <view class="duration">
        {{format.formatDuration(item.mv.videos[0].duration)}}
      </view>
    </view>
  </view>
  <view class="content">
    {{item.name}} - {{item.artistName}}
  </view>
</view>

②components/video-item/index.js (这里主要接收外部传进组件的数据item)

// components/video-item/index.js
Component({
  /**
   * 组件的属性列表
   */
  properties: {
    item:Object
  },

  /**
   * 组件的初始数据
   */
  data: {
  },

  /**
   * 组件的方法列表
   */
  methods: {

  }
})

 ③components/video-item/index.wxss

.item{
  width: 100%;
}
.album{
  position: relative;
  border-radius: 12rpx;
  overflow: hidden;
  display: flex;
}
.image{
  width: 100%;
}
.album .info{
  width: 100%;
  position: absolute;
  bottom: 10rpx;
  color: white;
  display: flex;
  justify-content: space-between;
  font-size: 24rpx;
  padding: 0 10rpx;
}
.info .count{
  padding-left: 36rpx;
  position: relative;
}
.info .duration{
  padding-right: 18rpx;
}
.info .count::before{
  content: "";
  position: absolute;
  left: -2rpx;
  top: 4rpx;
  width: 30rpx;
  height: 24rpx;
  background-size: cover;
  background-image: url("");
}
.content{
  margin-top: 10rpx;
  font-size: 28rpx;
  /*显示两行,超出部分使用省略号显示*/
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -moz-box;
  -moz-line-clamp: 2;
  -moz-box-orient: vertical;
  word-wrap: break-word;
  word-break: break-all;
  white-space: normal;
  overflow: hidden;
}

三.编写mv列表:包含(轮播图+视频列表[每个视频项引用组件来呈现])

 ①pages/index/index.js

import {getTopMV} from '../../service/api_video'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    MVData:[],//视频列表信息
    hasMore:true,//是否还有更多
    swiperHeight:"",//轮播图的高度
    orignIndex:Math.floor(Math.random()*30),//从[0,30)中取任意一个小数(向下取整)作为初始点
    orignCount:10,//每次请求获取10条数据
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.getTopMVData(this.data.orignIndex)
    console.log("初始点:"+this.data.orignIndex);
  },
/**
   * 由于载入图片之后,无法与swiper同高,所以加入下面的逻辑 
   * bindload载入时触发,获取载入图片之后dom的矩形信息==>
   * wx.createSelectorQuery().select(".swiper-image").boundingClientRect();
   * 如果是e.detail.height就是原图片的高度,性质不同。
   */
  queryRect:function(e) {
    let $this = this;
    const query = wx.createSelectorQuery();
    query.select(".swiper-image").boundingClientRect();
    query.exec(res=>{
      $this.setData({
        swiperHeight:res[0].height+"px"
      })
    })
  },
  //点击视频跳入详情页
  videoItemClick:function(e) {
    //获取当前视频的id
    const id = e.currentTarget.dataset.id
    //navigateTo会保留当前页面,并跳转到下个页面
    wx.navigateTo({
      url: '/pages/video_detail/index?id='+id,
    })
  },
 getTopMVData:async function(offset,str) {
   //如果是上拉,并且当前数据组的下次请求没有更多的数据了,则终止请求
   if(str === "reachbottom" && !this.data.hasMore) return
    // 获取从某个点开始的视频列表
    const res = await getTopMV(offset)
    // 获取当前的视频列表
    let newData = this.data.MVData
    // 如果是下拉刷新,直接覆盖视频列表
    if(str==="pulldown") {
      console.log("下拉了");
      newData = res.data
    }
    else{newData = newData.concat(res.data)}// 如果是上拉获取更多视频,则将新旧列表进行拼接
    // 更新视频列表,以及请求获取视频列表之后是否还有更多数据的判断变量
    this.setData({
      MVData:newData,
      hasMore: res.hasMore //是否还有更多
    })
 },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {
    //下拉刷新->随机刷新视频列表的初始点
    let orignIndex = Math.floor(Math.random()*30)
    this.setData({orignIndex})
    console.log("刷新后:"+this.data.orignIndex);
    this.getTopMVData(orignIndex,"pulldown")
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {
    //上拉获取更多数据->在原本的初始点上+当前视频列表的长度来作为此次请求的初始点
    this.getTopMVData(this.data.orignIndex+this.data.MVData.length,"reachbottom")
  },

})

 ②pages/index/index.json (这里要引入组件以及启动page的下拉触发函数)

{
  "enablePullDownRefresh": true,
  "backgroundTextStyle": "dark",
  "usingComponents": {
    "video-item":"/components/video-item/index"
    }
}

③pages/index/index.wxml 

<swiper class="swiper" autoplay indicator-dots circular interval="{{2000}}" style="height: {{swiperHeight}};">
  <block wx:for="{{[1,2,3,4,5,6,7]}}" wx:key="index">
    <swiper-item class="swiper-item">
      <image class="swiper-image" bindload="queryRect" src="/images/bannar/{{item}}.jpg" mode="widthFix" />
    </swiper-item>
  </block>
</swiper>
<view class="video">
  <view class="item" wx:for="{{MVData}}" wx:key="index">
  <video-item item="{{item}}" data-id="{{item.id}}" bindtap="videoItemClick"></video-item>
  </view>
</view>

 ④pages/index/index.wxss

page{
  padding: 0 20rpx;
}
.swiper{
  width: 95%;
  border-radius: 10rpx;
  overflow: hidden;
  transform: translateY(0);
}
.swiper-image{
  width: 100%;
}
.video{
  margin-top: 20rpx;
  width: 95%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.item{
  width: 48%;
  margin-top: 20rpx;
}

四.编写视频详情页

①pages/video_detail/index.js

// pages/video_detail/index.js
import {getMVDetail,getMVURL,getRelatedVideo} from '../../service/api_video'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    mvInfo:{},
    url:"",
    relatedData:[]
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    //获取跳转时传入的id
    var id = options.id
    this.getMVData(id)
  },

  getMVData:function(id){
    getMVDetail(id).then(res=>{
      this.setData({mvInfo:res.data})
    })
    getMVURL(id).then(res=>{
      this.setData({url:res.data.url})
    })
    getRelatedVideo(id).then(res=>{
      this.setData({relatedData:res.data})
    })
    console.log(this);
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})

②pages/video_detail/index.wxml

<!--pages/video_detail/index.wxml-->
<wxs src="../../utils/format.wxs" module="format"/>
<video src="{{url}}" class="video"></video>
<view class="detail">
  <view class="name">
    {{mvInfo.name}}
  </view>
  <view class="singer">
    {{mvInfo.artistName}}
  </view>
  <view class="info">
    {{format.formatCount(mvInfo.playCount)}}播放-{{mvInfo.publishTime}}
  </view>
</view>
<view class="related">
  <view wx:for="{{relatedData}}" class="item"  wx:key="index">
  <view class="image">
    <image src="{{item.coverUrl}}" mode=""/>
    <view class="imageInfo">
      <view class="count">
        {{format.formatCount(item.playTime)}}
      </view>
    </view>
    
  </view>
    <view class="relatedInfo">
      <view class="title">
        {{item.title}}
      </view>
      <view class="user">
      <block wx:for="{{item.creator}}" wx:key="index">
        {{item.userName}}
        <block wx:if="{{!index==item.creator.length}}">/</block>
      </block>
      </view>
    </view>
  </view>
</view>

③pages/video_detail/index.wxss文章来源地址https://www.toymoban.com/news/detail-449903.html

/* pages/video_detail/index.wxss */
.video{
  width: 100%;
}
.detail{
  margin: 20rpx 0 90rpx 50rpx;
}
.detail .name{
  font-weight: bold;
}
.detail .singer{
  font-size: 13px;
  margin: 10rpx 0; 
  color: gray;
}
.detail .info{
  font-size: 13px;
  color: gray;
}
.related{
  margin: 0 50rpx;
}
.item{
  display: flex;
  margin-bottom: 20rpx;
  width: 100%;
}
.item .image{
  width: 40%;
  height: 150rpx;
  margin-right: 20rpx;
  position: relative;
}
.item image{
  width: 100%;
  height: 100%;
  border-radius: 5px;
}
.item .relatedInfo{
  width: 58%;
}
.item .relatedInfo .title{
  font-size: 15px;
}
.item .relatedInfo .user{
  font-size: 12px;
  margin-top: 20rpx;
  color: gray;
}
.imageInfo {
  width: 100%;
  position: absolute;
  bottom: 10rpx;
  color: white;
  display: flex;
  justify-content: flex-end;
  font-size: 24rpx;
}
.imageInfo .count{
  padding-left: 36rpx;
  padding-right: 10rpx;
  position: relative;
}
.imageInfo .count::before{
  content: "";
  position: absolute;
  left: -2rpx;
  top: 4rpx;
  width: 30rpx;
  height: 24rpx;
  background-size: cover;
  background-image: url("");
}

到了这里,关于微信小程序之网易云音乐小案例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • uniapp 仿网易云音乐播放器 微信小程序

    uniapp 仿照网易云播放器功能

    2024年02月12日
    浏览(115)
  • 【微信小程序学习】网易云音乐歌曲详情页代码实现

    这里记录一下做网易云小程序的音乐播放详情页面的代码。 音乐播放界面的主要的重点有几个:   1、磁盘和摇杆的旋转效果,这里运用了css的动画属性   2、音乐播放和暂停,下一首/上一首等播放效果的实现   3、进度条的样式和控制   4、和上一页音乐推荐列表页通信,利

    2024年02月09日
    浏览(45)
  • 微信小程序网易云音乐设计与实现 毕业设计-附源码261620

    随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,微信小程序的网易云音乐系统被用户普遍使用,为方便用户能够可以随时进行微信小程序的网易云音乐系统的

    2024年02月05日
    浏览(36)
  • ssm+微信小程序网易云音乐设计与实现毕业设计源码261620

    随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,微信小程序的网易云音乐系统被用户普遍使用,为方便用户能够可以随时进行微信小程序的网易云音乐系统的

    2023年04月17日
    浏览(40)
  • SSM+微信小程序网易云音乐设计与实现 毕业设计-附源码261620

      随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,微信小程序的网易云音乐系统被用户普遍使用,为方便用户能够可以随时进行微信小程序的网易云音乐系统

    2024年02月10日
    浏览(41)
  • 网易云音乐小程序案例分享 附完整代码

    todo: 添加音乐到收藏(最近)列表 歌词滚动

    2023年04月24日
    浏览(38)
  • 案例026:基于微信小程序的音乐系统的设计与实现

    文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序运行软件:微信开发者 目录 前言 系统展示 管理员功能模块 用户功能模块 代码实现 登录功能实现代码 注

    2024年02月05日
    浏览(33)
  • 案例115:基于微信小程序的音乐播放器的设计与实现

    文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序运行软件:微信开发者 目录 目录 前言 系统展示 系统首页界面的设计实现 用户注册功能的设计实现 用户登

    2024年02月02日
    浏览(41)
  • 尚硅谷微信小程序开发 仿网易云音乐App 小程序 后端接口服务器搭建

    目录 小程序学习 视频相关的教程文档与笔记分享 配套服务器 源码地址: 接口使用说明文档 接口列表 启动服务 测试服务启动OK网页  http://localhost:3000/test.html​编辑  Postman测试服务器接口 postman配置 服务ip地址全局变量 ​编辑选择全局变量 登录接口测试 1. 发送验证码  手

    2024年02月09日
    浏览(47)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包