当前位置:   article > 正文

简洁版个人听歌小程序实战_微信小程序音乐实战

微信小程序音乐实战

以下是一个简单的音乐微信小程序示例代码,可以播放音乐和展示歌曲列表(需要进阶版优化版的可以在评论区艾特我哦):

目录

index.wxml

index.js

index.wxss

小程序功能简述:

项目总结:


index.wxml

  1. <!-- index.wxml -->
  2. <view class="container">
  3. <view class="header">我的音乐播放器demo</view>
  4. <view class="song-list">
  5. <block wx:for="{{songs}}" wx:key="index">
  6. <view class="song-item" bindtap="playSong" data-song="{{item}}">
  7. <text>{{item.name}}</text>
  8. </view>
  9. </block>
  10. </view>
  11. <audio hidden="{{!isPlaying}}" id="myAudio" src="{{currentSong.url}}" bindended="onSongEnded"></audio>
  12. </view>

index.js

  1. // index.js
  2. Page({
  3. data: {
  4. songs: [
  5. { name: "歌曲1", url: "http://www.example.com/song1.mp3" },
  6. { name: "歌曲2", url: "http://www.example.com/song2.mp3" },
  7. { name: "歌曲3", url: "http://www.example.com/song3.mp3" },
  8. ],
  9. isPlaying: false,
  10. currentSong: {},
  11. },
  12. playSong: function (event) {
  13. var song = event.currentTarget.dataset.song;
  14. this.setData({
  15. isPlaying: true,
  16. currentSong: song
  17. });
  18. var audioContext = wx.createAudioContext('myAudio');
  19. audioContext.play();
  20. },
  21. onSongEnded: function () {
  22. this.setData({
  23. isPlaying: false,
  24. currentSong: {}
  25. });
  26. }
  27. })

index.wxss

  1. /* index.wxss */
  2. .container {
  3. display: flex;
  4. flex-direction: column;
  5. align-items: center;
  6. }
  7. .header {
  8. font-size: 24px;
  9. margin-top: 20px;
  10. margin-bottom: 20px;
  11. }
  12. .song-list {
  13. display: flex;
  14. flex-direction: column;
  15. align-items: flex-start;
  16. }
  17. .song-item {
  18. padding: 10px;
  19. border-bottom: 1px solid #ccc;
  20. width: 100%;
  21. box-sizing: border-box;
  22. }
  23. .song-item:last-child {
  24. border-bottom: none;
  25. }

小程序功能简述:

这个示例中,`songs` 列表是一个包含歌曲信息的数组,每个歌曲都有 `name` 和 `url` 属性。

在页面渲染时,使用 `wx:for` 指令遍历 `songs` 数组,生成歌曲列表。

每个歌曲都是一个 `song-item` 元素,可以通过点击 `song-item` 元素来播放对应的歌曲。

项目总结:

在 JavaScript 中,通过 `bindtap` 事件绑定和 `data-song` 自定义属性传递被点击的歌曲信息。播放器的逻辑在 `playSong` 函数中,将点击的歌曲信息设置到 `currentSong` 中,然后通过 `wx.createAudioContext` 创建音频上下文,并调用 `play` 方法播放歌曲。

当歌曲播放结束后,通过 `bindended` 事件绑定的 `onSongEnded` 函数将 `isPlaying` 设置为 false,以便在页面中展示歌曲已停止播放。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/616309
推荐阅读
相关标签
  

闽ICP备14008679号