成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

?基于H5+js開發(fā)一款音樂播放器

BearyChat / 2805人閱讀

前言:當下音樂播放器不勝其數(shù),為了更好的掌握一些東西,我們來自己制作一個音樂播放器。


一.開發(fā)環(huán)境:

開發(fā)工具:HbuliderX;

框架:Vant,MuiVue

后端:Node


二.頁面視圖:

正常情況下我們的開發(fā)都會有構思圖以及模塊規(guī)劃等過程,我們先來看看大致的頁面構圖:

1.主文件入口(首頁):

2.音樂播放界面:


三.功能實現(xiàn)

項目文件布局:


(1)、index.html:

首先新建文件為h5+app項目,那么我們來看看其中index的頁面:

DOCTYPE html><html><head>    <meta charset="utf-8">    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />    <title>title>    <script src="./js/mui.min.js">script>    <link href="./css/mui.min.css" rel="stylesheet"/>		<script src="./js/vue.min.js">script>		<link rel="stylesheet" href="./css/vant.mim.css" rel="external nofollow" target="_blank" >		<script src="./js/vant.min.js" rel="external nofollow" >script>		<link rel="stylesheet" type="text/css" href="css/index.css"/>		<script type="text/javascript" src="./js/jquery.min.js">script>  head><body>	<div id="app">		<div class="head">			<header class="mui-bar mui-bar-nav">				<h1 class="mui-title">音樂播放器h1>			header>		div>		<div>			<van-notice-bar text="所有歌曲來自網(wǎng)易云,若有侵權聯(lián)系郵箱([email protected]" left-icon="volume-o" />		div>		<div class="contents">			<span style="display: inline-block;width: 100%;height: 5%;line-height:1.875rem;text-align: center;">當前存在:<strong>{{musicData.length}}strong>首歌曲(歌曲每天會進行實時更新)span>			<div class="contents_bottom">				<ul>					<li @click="seeMsg(index,item)" v-for="(item,index) in musicData" :key="index"><span style="padding-left: 0.625rem;font-size: 0.875rem;">{{index+1}}span> 						<span class="mui-icon mui-icon-arrowthinright">span>						<a href="javascript:;" :title="item" style="color: #000000;font-size: 1.125rem;">							<span style="margin-left: 3.125rem; ">{{item.substring(0,item.length-4)}}span>						a>					li>				ul>			div>		div>	div>	<script type="text/javascript" charset="utf-8">	  	mui.init();		var app = new Vue({		  el: "#app",		  data: {			  // 存儲所有音樂			  musicData:[]		  },		  created() {		  	this.get()		  },		  methods:{		  		//初始化獲取文件列表			  get(){				  var that=this				  $.get("http://www.jcsy.work:3333/see_music").then(res=>{					  if(res.code===200){						  vant.Toast("初始化數(shù)據(jù)獲取成功!");						  //vue中的渲染						  that.musicData=res.data					  }				  }).catch(e=>{					  vant.Toast.fail("服務異常,請稍候重試!");				  })			  },			  // 點擊跳轉傳參事件			  seeMsg(index,item){				  console.log(item)				  mui.openWindow({					  url:"music.html",					  extras: {    //extras里面的就是參數(shù)了					          name:{								  item:item,								  index:index							  }					    },				  })			  }		  }		})			script>body>html>

引入的文件都是通過下載本地的,為了減少app運行時數(shù)據(jù)加載的請求


(2)、播放音樂(music.html):

doctype html><html>	<head>		<meta charset="utf-8">		<title>title>		<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />		<link href="css/mui.css" rel="stylesheet" />		<link href="css/mui.min.css" rel="stylesheet"/>		<script src="js/mui.js">script>				<script src="./js/vue.min.js">script>				<link rel="stylesheet" href="./css/vant.mim.css" rel="external nofollow" target="_blank" >				<script src="./js/vant.min.js" rel="external nofollow" >script>				<link rel="stylesheet" type="text/css" href="css/index.css"/>				<script type="text/javascript" src="./js/jquery.min.js">script>	head>	<body>		<div id="music">			<div class="head">				<header class="mui-bar mui-bar-nav">					<a class="mui-action-back mui-icon mui-icon-left-nav mui-pull-left">a>					<h1 class="mui-title">{{names.substring(0,names.length-4)}}h1>				header>			div>			<div style="height: 93%;" class="contents">								<div class="img_photo">					<img id="imgshow" src="./img/zxc.jpg" >				div>								<div class="music_words">										<div>						<van-progress :percentage="count" pivot-text="" stroke-width="15"/>					div>					<span>歌曲全名:{{names}}span><br>						<p>						<span>							{{musicNow}}  /  {{musicLength}}						span> 						p>					<span>暫無歌詞,持續(xù)更新中...span>				div>								<div class="music_manager">										<img src="img/up.png" @click="upMusic">										<img id="start" src="./img/pause.png" @click="loadMusic">										<img src="img/down.png" @click="downMusic">				div>				<div style="width: 100%;height: 5%;background-color: #dfdfdf;text-align: center;line-height:2.1875rem;">					<span>						Copyright?2021 <strong>叫做長大strong>					span>				div>								<audio id="audio" :src="musicname" preload>			div>		div>		<script type="text/javascript">			mui.init()			mui.plusReady(function(){			    var self = plus.webview.currentWebview();			    var name = self.name;//獲得參數(shù)				var app = new Vue({				  el: "#music",				  data() {				  	return{				  	//標題欄的歌曲名						names:"",						//播放音樂的鏈接						musicname:"",						//存儲歌曲名的						musicData:[],						//歌曲的總長度						musicLength:"",						//當前歌曲的進度						musicNow:"00:00",						//進度條的百分比						count:""					}				  },				  created() {					var that=this				  	that.names=name.item					that.musicname="http://www.jcsy.work:3333/music/"+(name.item)					that.get()					// 初始化獲取歌曲時長					setTimeout(function(){						var music = document.getElementById("audio");						that.musicLength=that.secondToTimeStr(Math.round(music.duration))					},500)				  },				  methods:{					  // 刷新所有的數(shù)據(jù)					  get(){						  var that=this						  $.get("http://www.jcsy.work:3333/see_music").then(res=>{								  if(res.code===200){									  that.musicData=res.data								  }						  }).catch(e=>{								  vant.Toast.fail("服務異常,請稍候重試!");						  })					  },					  // 上一首					  upMusic(){						  var that=this						  var music = document.getElementById("audio");						  if(name.index<0){							  name.index=that.musicData.length+1						  }						  that.musicNow="00:00"						   $("#start").attr("src","./img/pause.png")						   name.index--						  that.names=that.musicData[name.index]						  that.musicname="http://www.jcsy.work:3333/music/"+that.names						  // $("#start").attr("src","./img/start.png")						  that.musicLength=that.secondToTimeStr(Math.round(music.duration))						  that.getMusic()						  music.play()					  },					  // 下一首					  downMusic(){						  var that=this						  var music = document.getElementById("audio");						  if(name.index>=that.musicData.length){							   name.index=-1						  }           
               
                                           
                       
                 

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/121474.html

相關文章

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<