亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JS HTML5 音樂天氣播放器(Ajax獲取天氣信息)

2019-11-20 22:41:14
字體:
來源:轉載
供稿:網友
晚上要考軟件工程,實在不想復習。寫個播放器吧,這個只是個用來學習的小Demo,眾多不完善之處,下面貼出源代碼,如果要轉載,請加上版權聲明

PS:因為Ajax涉及到跨域獲取天氣信息,有兩個版本,一個是直接跨域,IE10支持,其他的瀏覽器要改配置。另一個是服務器端的weather.php,獲取天氣信息返回json。
weather.php就不寫了,里面的對應路徑存放對應的文件

演示地址:
http://569375.ichengyun.net/fm/

實現功能:
音樂播放,進度調節(滑動模塊),音量條件,音樂隨機選擇,背景圖片,圖片預加載,音樂預加載,天氣Ajax獲取
音樂列表使用的json處理(也可以理解是hash表)
復制代碼 代碼如下:

<!DOCTYPE html >
<html>
<head>
<title>音樂天氣</title>
<meta charset='utf-8' />
</head>
<style type='text/css'>
body{margin:0; padding:0; }
.clear{clear:both;}
#weather-body{margin:0; padding:0; }
#weather{ position:absolute;left:20px; top:30px;font-family:"Microsoft YaHei","SimHei";}
#weather p{ }
p#weather-city{ width:100px; color:#FFF; margin:20px; font-size:28px; }
p#weather-temperature{ width:200px; color:#FFF; margin:20px; margin-left:50px; font-size:32px;}
p#weather-stat{ width:200px; color:#FFF; margin:20px; font-size:26px; }
#music-box{ position:absolute;right:20px; padding:30px;filter:alpha(opacity=70);-moz-opacity:0.7;-khtml-opacity: 0.7;opacity: 0.7;bottom:30px; text-align:center;}
#music-box div{ }
#music-box:hover{filter:alpha(opacity=100);-moz-opacity:1;-khtml-opacity: 1;opacity: 1;}
h2#song-title{ font-family:"Microsoft YaHei","SimHei"; color:#fff;}
h3#song-author{font-family:"Microsoft YaHei","SimHei"; color:#fff;}
div#music-process{ width:400px;}
div#music-process-p{float:left; margin:0px 20px 0 20px; display:block;width:290px;background:url(./images/button.gif) 0 -133px repeat-x ; height:40px; }
span#music-process-slide{ cursor:pointer;display:block;float:left; width:30px;background:url(./images/button.png) -30px -230px no-repeat ; height:30px;}
div#music-ctime{display:block; float:left; color:#FFF; font-weight:bold; width:40px;height:30px;font-family:"Arial";}
div#music-etime{display:block; float:left; color:#FFF;font-weight:bold;width:40px;height:30px;font-family:"Arial";}
div#music-play{ cursor:pointer; display:none;margin:10px auto;width:100px; border:0px #FFF solid; background:url(./images/button.png) 0 -12px no-repeat ; height:70px;}
div#music-next{cursor:pointer;display:none; margin:10px auto; width:100px; margin-top:15px; border:0px #FFF solid; background:url(./images/button.png) 0 -85px no-repeat ; height:40px;}
div#music-volume{float:right; margin:10px;width:50px;}
div#music-volume-v{float:left; display:block;width:50px;background:url(./images/button.png) 3px -250px no-repeat ; height:100px; }
span#music-volume-slide{cursor:pointer;display:block;float:left; width:40px;background:url(./images/button.png) 0px -353px no-repeat ; height:30px;}
</style>
<script type="text/javascript" >
/*
版權聲明
作者:EI Nino
Email:Jinyachen@gmail.com
*/
var music ='';
var musicBox ='';
var musicPlay='';
var musicNext='';
var musicV='';
var musicProcess='';
var musicSlide='';
var musicSlideLeft=0;
var musicCtime='';
var musicEtime='';
var musicVolume='';
var musicVolumeSlide='';
var mouseX='';
var mouseY='';
var mouseDown=false;
var bdy='';
var backgroundImages=new Array();
var backgroundNumber=1;
var songNumver=1;
var playList=new Array();
var nextSong='';
var songs=new Array();
//**************************************//
//INIT WEB
//*************************************//
function init(){
//**************************************//
//Musci Box
//*************************************//
musicBox = document.getElementById("music-box");
musicPlay= document.getElementById('music-play');
musicNext= document.getElementById('music-next');
musicCtime=document.getElementById('music-ctime');
musicEtime=document.getElementById('music-etime');
musicSlide=document.getElementById('music-process-slide');
musicProcess=document.getElementById('music-process-p');
musicVolume=document.getElementById('music-volume-v');
musicVolumeSlide=document.getElementById('music-volume-slide');
musicSlide.style.marginLeft="0px";
musicProcess.style.width="270px";
bdy=document.getElementsByTagName('body');
bdy=bdy[0];
var screenH = window.screen.height;
var screenW = document.body.clientWidth;
//Background cache //
backgroundNumber =Math.ceil(Math.random()*10);
backgroundImages[0] =new Image();
backgroundImages[1]= new Image();
backgroundImages[0].src= "./rain/"+backgroundNumber+".jpg";
backgroundImages[1].src= "./rain/"+(backgroundNumber >= 10 ? 1:backgroundNumber+1)+".jpg";
bdy.style.background="url("+backgroundImages[0].src+") top";
//*****************//
music = document.getElementsByTagName('audio');
music = music[0];
music.autobuffer=true;
setInterval(mProcess,1000);
musicProcess.addEventListener('mousedown',mSlideProcessDown);
musicProcess.addEventListener('mousemove',mSlideProcessMove);
musicProcess.addEventListener('mouseup',mSlideProcessUp);
musicVolume.addEventListener('mousedown',mSlideVolumeDown);
musicVolume.addEventListener('mousemove',mSlideVolumeMove);
musicVolume.addEventListener('mouseup',mSlideVolumeUp);
//*******************Music Box end******************//
//********************************************************//
//Weather Box
//*******************************************************//
var wget = new XMLHttpRequest();
var url="";
url='./weather.php';
url="http://m.weather.com.cn/data/101110200.html";
var weatherInfo=new Array();
wget.open('GET',url);
wget.onreadystatechange=function(){
if(wget.readyState=='4' &&wget.status==200)
{
weatherInfo= wget.responseText;
weatherInfo=eval("["+weatherInfo+"]");
weatherInfo=weatherInfo[0]['weatherinfo'];
document.getElementById('weather-city').innerHTML=weatherInfo['city'];
document.getElementById('weather-temperature').innerHTML=weatherInfo['temp1'];
document.getElementById('weather-stat').innerHTML=weatherInfo['weather1'];
}
}
wget.send("User-Agent:Mozilla/4.04[en](Win95;I;Nav)");
//*******************Weather Box end*************************************//
}
function mProcess(){
if(1)
{
var ctime = music.currentTime;
var time = Math.floor(ctime/60)+":"+(Math.floor(ctime-60*Math.floor(ctime/60))<10 ? "0"+Math.floor(ctime-60*Math.floor(ctime/60)) : Math.floor(ctime-60*Math.floor(ctime/60)));
var time2 =music.duration-music.currentTime;
var etime=Math.floor(time2 /60)+":"+(Math.floor(time2-60*Math.floor(time2/60))<10 ? "0"+Math.floor(time2-60*Math.floor(time2/60)) : Math.floor(time2-60*Math.floor(time2/60)));
var ra = music.currentTime/music.duration;

var mpw=musicProcess.style.width;
mpw = mpw.substring(0,mpw.indexOf('px'));
musicSlide.style.marginLeft = mpw *ra+"px";

musicCtime.innerHTML=time;
musicEtime.innerHTML=etime;
if(music.ended==true)
{
mRandPlay();
}
}
}
//**************************************************************//
//Process
//**************************************************************//
function mSlideProcessDown(e){
mouseDown=true;
mouseX = e.pageX;
}
function mSlideProcessMove(e){
if(mouseDown==true)
{
var mLeft= (e.pageX-mouseX);
var t2 = music.currentTime+music.duration*mLeft/musicProcess.style.width.substring(0,musicProcess.style.width.indexOf('px'));
t2=t2>0 ? t2:0;
mLeft=musicProcess.style.width.substring(0,musicProcess.style.width.indexOf('px'))*t2/music.duration;
musicSlide.style.marginLeft= (mLeft>0&&mLeft<300 ? mLeft:0)+"px";

}
}
function mSlideProcessUp(e){
if(mouseDown==true)
{
mouseDown=false;

var mLeft= (e.pageX-mouseX);
var t2 = music.currentTime+music.duration*mLeft/musicProcess.style.width.substring(0,musicProcess.style.width.indexOf('px'));
mLeft=musicProcess.style.width.substring(0,musicProcess.style.width.indexOf('px'))*t2/music.duration;
t2=t2>0 ? t2:0;
musicSlide.style.marginLeft= (mLeft>0&&mLeft<300 ? mLeft:0)+"px";
mouseDown=false;
mouseX=0;

music.currentTime=t2;


}
mouseDown=false;
}
//**********************Process end****************************************//
//**************************************************************//
//Volume//
//**************************************************************//
function mVolume(){
music.volume=0.5;
musicVolumeSlide.style.marginTop = 70 *(1-music.volume)+"px";
}
var vT=0;
var aT=0;
function mSlideVolumeDown(e){
mouseDown=true;
mouseY = e.pageY;
if(musicVolume.style.height=='')
musicVolume.style.height="100px";
vT = musicVolumeSlide.style.marginTop.substring(0,musicVolumeSlide.style.marginTop.indexOf('px'));
aT= musicVolumeSlide.style.marginTop.substring(0,musicVolumeSlide.style.marginTop.indexOf('px'))/musicVolume.style.height.substring(0,musicVolume.style.height.indexOf('px'));

}
function mSlideVolumeMove(e){
if(mouseDown==true)
{
var mTop= (e.pageY-mouseY);
//document.getElementById('show-statu').innerHTML=aT*musicVolume.style.height.substring(0,musicVolume.style.height.indexOf('px'))+mTop;
mTop=aT*musicVolume.style.height.substring(0,musicVolume.style.height.indexOf('px'))+mTop;
musicVolumeSlide.style.marginTop= (mTop>0&&mTop<100 ? mTop:0)+"px";

}
}
function mSlideVolumeUp(e){
if(mouseDown==true)
{
mouseDown=false;
var mTop= (e.pageY-mouseY);
mTop=aT*musicVolume.style.height.substring(0,musicVolume.style.height.indexOf('px'))+mTop;
musicVolumeSlide.style.marginTop= (mTop>0&&mTop<100 ? mTop:0)+"px";
mouseDown=false;
mouseY=0;
music.volume=1-mTop/100;
}
mouseDown=false;
}
//**********************Volume end****************************************//
/*
播放和暫停按鈕
*/
function mPlay(){
var time = Math.floor(music.duration/60)+"分"+Math.floor(music.duration-60*Math.floor(music.duration/60))+"秒";
switch(music.paused){
case true:
{
music.play();
musicPlay.style.background="url(./images/button.png) 0 -159px no-repeat";
break;
}
case false:
{
music.pause();
musicPlay.style.background="url(./images/button.png) 0 -12px no-repeat";
break;
}
}
}
/*
載入歌曲
*/
var songNum=1;
function loadSongs(){
playList={0:11,
1:{'title':"我們沒有在一起",'author':'劉若英','src':"./storage/womenmeiyouzaiyiqi.mp3"},
2:{'title':"Apologize",'author':'Onerepublic','src':"./storage/Apologize.mp3"},
3:{'title':"Breathless",'author':'Shayne Ward','src':"./storage/Breathless.mp3"},
4:{'title':"Call Me Maybe",'author':'Carly Rae Jepsen','src':"./storage/Carly Rae Jepsen - Call Me Maybe.mp3"},
5:{'title':"valder fields",'author':'tamas wells','src':"./storage/tamas-wells-valder-fields.mp3"},
6:{'title':"不再聯系",'author':'夏天Alex','src':"./storage/buzailianxi.mp3"},
7:{'title':"What Are Words",'author':'chris medina','src':"./storage/What Are Words.mp3"},
8:{'title':"you can trust in me",'author':'tang nguoi toi yeu','src':"./storage/tang nguoi toi yeu - you can trust in me.mp3"},
9:{'title':"Stay Here Forever",'author':'Jewel','src':"./storage/Stay Here Forever.mp3"},
10:{'title':"淚的物語",'author':'Oceans Of Love','src':"./storage/tears.mp3"},
11:{'title':"親愛的路人",'author':'劉若英','src':"./storage/qinaideluren.mp3"},
};
//Songs cache and change//
var listCount = playList[0];
var num =Math.ceil(Math.random()*10)%(listCount+1);
songNum=num;
if(songNum>listCount)
songNum=1;
num=songNum;
songs[0]=playList[num>0? num :num+1];
num=((songNum+1) > listCount ? 1 : (songNum+1));
songs[1]=playList[num>0? num :num+1];
music.src=songs[0]['src'];
nextSong = new Audio();
nextSong.src=songs[1]['src'];
nextSong.load();
//**************************//
document.getElementById('song-title').innerHTML=songs[0]['title'];
document.getElementById('song-author').innerHTML=songs[0]['author'];
setTimeout(canPlay,2000);
setTimeout(canRand,30000);
}
/*
隨機播放列表的歌曲
*/
function mRandPlay()
{
//Backgorund cache and change//
backgroundNumber =Math.ceil(Math.random()*10);
bdy.style.background="url("+backgroundImages[1].src+") top";
backgroundImages[1].src= "./rain/"+(backgroundNumber >= 10 ? 1:backgroundNumber+1)+".jpg";
//***************//
var listCount = playList[0];
//Songs cache and change//
music.pause();
music=nextSong;
document.getElementById('song-title').innerHTML=songs[1]['title'];
document.getElementById('song-author').innerHTML=songs[1]['author'];
var num =Math.ceil(Math.random()*10)%(listCount+1);
songNum+=1;
if(songNum>listCount)
songNum=1;
num=songNum;
songs[1]=playList[num>0? num :num+1];
nextSong = new Audio();
nextSong.src=songs[1]['src'];
nextSong.load();
//***************//
//musicPlay.style.display='block';
musicNext.style.display='none';
setTimeout(canRand,30000);
mPlay();
}
function canPlay(){
musicPlay.setAttribute('onClick','javascript:mPlay()');
musicPlay.style.display='block';
}
function canRand(){
musicNext.setAttribute('onClick','javascript:mRandPlay()');
musicNext.style.display='block';
}
</script>
<body >
<div id='weather-body'>
<div id='weather'>
<p id='weather-city'>喜歡一個人</p>
<p id='weather-temperature'>不難</p>
<p id='weather-stat'>被同一個人喜歡<br/>好難</p>
</div>
<div id='music-box'>
<audio src="./storage/我們沒有在一起.mp3" >
您的瀏覽器暫不支持HTML5 請選擇Google chrome或其他支持HTML5的瀏覽器
</audio>
<div id='music-process'>
<h2 id='song-title'></h2>
<h3 id='song-author'></h3>
<div id='music-ctime'>0:00</div>
<div id='music-process-p'>
<span id='music-process-slide'>
</span>
</div>
<div id='music-etime'>0:00</div>
<br class='clear' />
</div>
<div id='music-volume'>
<div id='music-volume-v'>
<span id='music-volume-slide'>
</span>
</div>
<br class='clear' />
</div>
<div id='music-play' ></div>
<div id='music-next' ></div>
<br class='clear' />
</div>
</body>
<script type="text/javascript" >
window.onload=init();
mVolume();
loadSongs();
</script>
</html>

文件目錄結構:
images:存放botton.png
rain:存放背景
storage:存放mp3格式音樂

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91国产精品视频在线| 自拍偷拍亚洲欧美| 日韩亚洲综合在线| 国产日韩av在线播放| 中文字幕最新精品| 2021国产精品视频| 欧洲日韩成人av| 亚洲综合在线中文字幕| 欧美精品videos另类日本| 成人午夜在线观看| 91大神在线播放精品| 久久精品2019中文字幕| 欧美视频一二三| 亚洲欧洲午夜一线一品| 欧美孕妇性xx| 欧美激情一区二区三级高清视频| 亚洲人成在线免费观看| 亚洲黄色av网站| 亚洲欧美一区二区三区在线| 成人网址在线观看| 亚洲tv在线观看| 欧美精品日韩三级| 色综合天天综合网国产成人网| 国产精品三级久久久久久电影| 欧美日韩在线视频首页| 亚洲成年网站在线观看| 日韩精品www| 最新日韩中文字幕| 午夜精品福利电影| 欧美精品免费在线| 96pao国产成视频永久免费| 欧美激情一区二区三区高清视频| 欧美精品午夜视频| 午夜欧美大片免费观看| 日本高清视频一区| 最近2019中文字幕mv免费看| 久久av在线播放| 欧美激情视频网| 欧美丝袜第一区| 国产三级精品网站| 日本高清+成人网在线观看| 91亚洲精品久久久久久久久久久久| 精品一区二区三区四区在线| 欧美一级片在线播放| 亚洲色图18p| 欧美黑人极品猛少妇色xxxxx| 中文字幕日韩av| 美女视频黄免费的亚洲男人天堂| 91精品视频免费| 欧美制服第一页| 久久精品91久久香蕉加勒比| 国产精品视频色| 亚洲人精选亚洲人成在线| 8x海外华人永久免费日韩内陆视频| 黑人巨大精品欧美一区二区| 国产中文欧美精品| 亚洲欧美制服综合另类| 91九色在线视频| 国产精品v片在线观看不卡| 欧美一乱一性一交一视频| 欧美综合激情网| 午夜精品国产精品大乳美女| 日韩专区中文字幕| 欧美巨猛xxxx猛交黑人97人| 日韩精品极品视频免费观看| 日韩精品久久久久久福利| 久久久国产成人精品| 国产97在线观看| 91久久国产婷婷一区二区| 国内免费久久久久久久久久久| 国产成人激情视频| 亚洲视频999| 日韩av网站电影| 亚洲网在线观看| 欧美另类第一页| 成人欧美一区二区三区在线湿哒哒| 久久福利视频导航| 欧美午夜女人视频在线| 亚洲免费电影在线观看| 伊人久久久久久久久久久| 亚洲区一区二区| 久久久999精品| 少妇激情综合网| 欧美日韩免费区域视频在线观看| 色婷婷av一区二区三区久久| 国产精品夫妻激情| 欧美成人亚洲成人日韩成人| 欧美猛少妇色xxxxx| 久久久国产视频91| 久久精品色欧美aⅴ一区二区| 欧美一级在线亚洲天堂| 色老头一区二区三区在线观看| 日本欧美爱爱爱| 福利一区福利二区微拍刺激| 欧美日韩国产综合视频在线观看中文| 国产98色在线| 国产精品久久久久久久av电影| 欧美激情影音先锋| 欧美激情在线狂野欧美精品| 日韩毛片中文字幕| 日韩视频永久免费观看| 欧美中文在线免费| 日韩精品免费在线观看| 91极品女神在线| 日韩成人中文字幕| 亚洲欧洲在线免费| 久久影视电视剧免费网站清宫辞电视| 亚洲精品久久久一区二区三区| 国产精品精品久久久久久| 欧美日韩国产精品一区| 日韩av在线不卡| 日韩网站在线观看| 亚洲一区999| 亚洲系列中文字幕| 成人久久18免费网站图片| 日韩欧美a级成人黄色| 亚洲精品久久久一区二区三区| 国产精品热视频| 神马国产精品影院av| 成人国产精品色哟哟| 九九久久综合网站| 欧美猛交免费看| www.亚洲免费视频| 国产欧美一区二区白浆黑人| 国产精品老牛影院在线观看| 亚洲国产精品va在线观看黑人| 98精品国产高清在线xxxx天堂| 91九色视频导航| 国产视频精品久久久| 亚洲第一男人天堂| 亚洲国产一区二区三区在线观看| 国产视频亚洲精品| 亚洲人成网站777色婷婷| 伊人亚洲福利一区二区三区| 亚洲欧美国产精品久久久久久久| 97在线免费观看| 欧美日韩免费观看中文| 日韩中文字幕精品| 国内久久久精品| 国产有码在线一区二区视频| 黄色一区二区三区| 亚洲精品国产电影| 国产一区二区三区在线看| 国产精品视频网址| 欧美激情a在线| 亚洲性69xxxbbb| 日韩va亚洲va欧洲va国产| 青青草国产精品一区二区| 欧美性猛交xxxx黑人| 欧美久久精品午夜青青大伊人| 日韩av在线直播| 九九精品在线视频| 欧美黑人xxxx| 欧美高清不卡在线| 91精品视频在线免费观看| 亚洲天堂第一页| 国产欧亚日韩视频| 亚洲人成电影在线观看天堂色| 欧美激情综合色综合啪啪五月| 久久久精品久久| 综合国产在线观看| 日韩在线中文字| 2019中文字幕全在线观看| 亚洲成在人线av|