import Vue from 'vue' import App from './App' import store from '@/store' Vue.config.productionTip = false App.mpType = 'app' Vue.prototype.$store = store const app = new Vue({ store }) app.$mount()
这样就可以在项目中正常使用啦,完全支持 mapState , mapActions , mapGetters 的写法,比如在 pages/index/index.vue 中使用:
<script> import { mapState, mapActions } from 'vuex' export default { computed: { ...mapState(['myAudio']) }, methods: { ...mapActions(['myActions']) }, created () { this.myActions() //调用vuex中的方法 } } </script>
踩坑指南
其实大多数坑可能是mpvue的,很多情况也是自己不熟悉小程序生命周期导致的一些奇奇怪怪的bug。
mpvue是支持小程序原生组件的
mpvue会将 div 编译为小程序中的 view 。一开始我不了解,以为用了mpvue后就不能使用小程序原生支持的组件了,比如 swiper , scroll-view 等,小程序是支持的,可以放心使用哈哈。
npm run build后样式丢失
本来在开发环境正常的,然后准备发版 npm run build 后发现样式丢失了。然后重新 npm start 排查问题,样式还是丢失的。内心此时是mmp的:npm run build丢失就算了,我没改什么东西重新npm start后为什么还是丢失,之前还是正常的呀?
刚开始怀疑是缓存什么的问题,删掉的dist目录,重启开发者工具,甚至重启电脑都试了一下,这是我遇到的超级诡异的问题之一。
冷静下来想到:之前的版本是正常的,一定是新版本引入了什么导致了打包样式的丢失。于是回滚版本一个个build排查问题,最后找到了原因: 在一个page中引入了其他page,即在页面中import另一个页面。
在我这里的具体例子是:我在 pages/index/index.vue 中想做底部共用一个tabbar,页面根据tabbar的值来显示对应的子级页面: pages/page1/index.vue 和 pages/page2/index.vue 。
所以我将这两个页面当做子组件来引入了: import Page1 from '@/pages/page1' ,一开始没有问题,等重启项目,或者build后就发现样式丢失了。
这可能是mpvue打包机制的一个限制,即 页面不能将另一个页面当子组件来引用 ,否则会导致样式丢失。
背景音频的src无法读取
项目中希望用户退出小程序后依然能播放音频,所以用到了背景音频的api: wx.getBackgroundAudioManager()。
this.audio = wx.getBackgroundAudioManager() this.audio.src = 'http://ws.stream.qqmusic.qq.com/M500001VfvsJ21xFqb.mp3?guid=ffffffff82def4af4b12b3cd9337d5e7&uin=346897220&vkey=6292F51E1E384E061FF02C31F716658E5C81F5594D561F2E88B854E81CAAB7806D5E4F103E55D33C16F3FAC506D1AB172DE8600B37E43FAD&fromtag=46' this.audio.title = '此时此刻' //注意必填 this.audio.epname = '此时此刻' this.audio.singer = '许巍' this.audio.coverImgUrl = 'http://y.gtimg.cn/music/photo_new/T002R300x300M000003rsKF44GyaSk.jpg?max_age=2592000'
title 和 src 赋值后会直接播放音频,后面的几个属性建议也填上,因为播放背景音频时微信是有个界面需要封面图和歌手名称等的。
如果想要获取当前正在播放的音频src,本来以为通过 this.audio.src 来获取就可以了但是有bug。
在开发者工具中是可以正常获取的,即开发时是没问题的,但在真机上返回的是 undefined ,因此不能用 this.audio.src 来获取当前播放的音频url,得用一个变量来存这个数据。
直接使用音频的currentTime可能渲染不及时
currentTime用于显示当前的播放进度,但我用在子组件中时经常更新不及时,打印是正常的,但试图渲染不及时,有时候需要点击一下才能重新渲染,这可能是mpvue使用时才会遇到。
所以建议还是项目自身维护一套背景音频的变量比较好一点,比如放在 vuex 中。监听 BackgroundAudioManager.onTimeUpdate() 方法每次赋值到自身维护的变量中。
音频的onCanplay方法不一定每个音频都会触发
一开始我监听在 onCanplay 方法,将音频的时长信息 duration 赋值到vuex中存起来,但发现 onCanplay 有时候是不会触发的,比如重新赋值src播放下一首时,很尴尬。
所以不要太依赖onCanplay这个方法,还好目前直接使用 audio.duration 好像不会出现像上面的 currentTime 渲染不及时的问题,所以就这样用着先。
音频播放结束,即onStop后,不能再通过audio.play()的方法重新播放,得重新赋值src