用微信小程序做个简单的音乐
用微信小程序完成搭建后首先在app.josn的pages里加个 "pages/indexprojrct/indexprojrct"保存。
你会发现它自动跟你生成。
在indexprojrct.wxml:
<view class="songCss" style="flex-direction:column;"> <input class="kb" placeholder="请输入歌名" name='songName' bindinput="insongname"/> <button catchtap="looksong">搜索</button> <view> <audio name="{{playing.name}}" author="{{playing.author}}" src="{{playing.url}}" id="audioCtx" controls loop bindtap="isplaySong"></audio> </view> <view wx:for='{{songList}}' data-music="{{item}}" data-author="{{item.artists[0].name}}" bindtap="playSong"> <text>歌名:{{item.name}}</text> <text>歌手:{{item.artists[0].name}}</text> <view class="kb"></view> </view> </view>
在indexprojrct.js:
Page({ /** * 页面的初始数据 */ data: { isPlay:false, audioCtx:{}, playing:{ name:'', url:'', author:'' },//当前播放的音乐的地址 songName: "", songList:[],//歌曲列表 }, insongname(e) { this.setData({ songName: e.detail.value }) }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { var that = this; }, looksong: function (e) { // console.log(this.data.songName); var songname = this.data.songName; // console.log(songname); var that=this; wx.request({ //url: 'http://musicapi.leanapp.cn/search?keywords=' + songname, url:'http://musicapi.xiecheng.live/search?keywords='+songname, success: function (res) { console.log(res.data.result.songs); var list=res.data.result.songs; that.setData({ songList:list }) } }) }, //播放音乐 playSong(e){ let {music} =e.currentTarget.dataset; let {author} =e.currentTarget.dataset; // console.log('https://music.163.com/song/media/outer/url?id='+id); var that=this; wx.request({ // url: 'https://music.163.com/song/media/outer/url?id='+id, url:'https://autumnfish.cn/song/url?id='+music.id, header: { 'content-type': 'application/x-www-form-urlencoded' }, method:'GET', dataType:'json', success:function(res){ console.log(res); var musicItem=that.data.playing; musicItem.url= res.data.data[0].url; musicItem.name=music.name; musicItem.author=author; that.setData({ playing:musicItem }) that.data.audioCtx.play(); that.data.isPlay=true; } }) }, isplaySong(){ var b= !this.data.isPlay; // console.log(b); this.setData({ isPlay:b }) if(b){ this.data.audioCtx.play(); }else{ this.data.audioCtx.pause(); } }, /** * 生命周期函数--监听页面初次渲染完成 */ onReady: function () { this.data.audioCtx=wx.createAudioContext('audioCtx') }, /** * 生命周期函数--监听页面显示 */ onShow: function () { }, /** * 生命周期函数--监听页面隐藏 */ onHide: function () { }, /** * 生命周期函数--监听页面卸载 */ onUnload: function () { }, /** * 页面相关事件处理函数--监听用户下拉动作 */ onPullDownRefresh: function () { }, /** * 页面上拉触底事件的处理函数 */ onReachBottom: function () { }, /** * 用户点击右上角分享 */ onShareAppMessage: function () { } })
在indexprojrect.wcss里你可以装饰你的页面了
这样就完成了!!!