解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题


Posted in Javascript onAugust 03, 2018

前言

最近博主正在用微信小程序开发一款网上商城系统。恰好赶上了美团开源的小程序开发框架mpvue。该框架继承了vue.js的特性,用起来还是蛮爽的。然后在开发中,数据仓库这块懵逼了, 引入的vuex的辅助函数mapState、mapGetters、mapMutations、mapActions等怎么就不能用呢。苦恼之际打开D盘,一番愉悦之后,终于想通啦…

问题分析

•vuex辅助函数

 首先简单说一下vuex的辅助函数mapState、mapGetters、mapMutations、mapActions,我们在子组件经常用到很多状态量,为了避免过分的使用this.$store.state.xxx、this.$store.dispatch导致的冗余问题,我们用辅助函数来使代码变得简洁易读。注意了,它就相当于语法糖似的,实际上还会映射为this.$store.吧啦吧啦

•vue-cli + vuex项目

 在一般的vue-cli + vuex项目中,主函数 main.js 中会将 store 对象提供给 “store” 选项,这样可以把 store 对象的实例注入所有的子组件中,从而在子组件中可以用this.$store.state.xxx、this.$store.dispatch 等来访问或操纵数据仓库中的数据

new Vue({
el: '#app',
store,
router,
template: '<App/>',
components: { App }
})

•mpvue + vuex项目

 注意了,在mpvue + vuex项目中,很遗憾不能通过上面那种方式来将store对象实例注入到每个子组件中(至少我尝试N种配置不行),也就是说,在子组件中不能使用this.$store.吧啦吧啦,从而导致辅助函数不能正确使用。这个时候我们就需要换个思路去实现,要在每个子组件中能够访问this.$store才行。

解决办法

这里呢,博主使用的方法很简单,既然我们需要在子组件中用this.$store 访问store实例,那我们直接在vue的原型上添加$store属性指向store对象不就行啦,抱着试一试的心态写了下面这行代码。

Vue.prototype.$store = store

这样一来我们在子组件中便可以用this.$store访问对象。确实也解决了辅助函数不能使用的问题。

总结

以上所述是小编给大家介绍的解决mpvue + vuex 开发微信小程序 vuex辅助函数mapState、mapGetters不可用问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
科讯商业版中用到的ajax空间与分页函数
Sep 02 Javascript
javascript学习笔记(七)利用javascript来创建和存储cookie
Apr 08 Javascript
兼容主流浏览器的iframe自适应高度js脚本
Jan 10 Javascript
javascript制作坦克大战全纪录(2)
Nov 27 Javascript
javascript 注释代码的几种方法总结
Jan 04 Javascript
javascript 数据存储的常用函数总结
Jun 01 Javascript
基于 Vue.js 之 iView UI 框架非工程化实践记录(推荐)
Nov 21 Javascript
使用 Node.js 开发资讯爬虫流程
Jan 07 Javascript
详解如何在Node.js的httpServer中接收前端发送的arraybuffer数据
Nov 11 Javascript
微信小程序文章详情页跳转案例详解
Jul 09 Javascript
uni-app 组件里面获取元素宽高的实现
Dec 27 Javascript
将Vue组件库更换为按需加载的方法步骤
May 06 Javascript
mpvue跳转页面及注意事项
Aug 03 #Javascript
JavaScript高级函数应用之分时函数实例分析
Aug 03 #Javascript
mpvue小程序仿qq左滑置顶删除组件
Aug 03 #Javascript
JavaScript中call和apply方法的区别实例分析
Aug 03 #Javascript
JavaScript捕捉事件和阻止冒泡事件实例分析
Aug 03 #Javascript
关于js对textarea换行符的处理方法浅析
Aug 03 #Javascript
webpack4 + react 搭建多页面应用示例
Aug 03 #Javascript
You might like
DOTA2 玩家自创拉野攻略 特色英雄快速成长篇
2020/04/20 DOTA
PHP框架性能测试报告
2016/05/08 PHP
YII框架中使用memcache的方法详解
2017/08/02 PHP
jquery之Document元素选择器篇
2008/08/14 Javascript
Jquery Ajax学习实例3 向WebService发出请求,调用方法返回数据
2010/03/16 Javascript
基于jQuery的输入框在光标位置插入内容, 并选中
2011/10/29 Javascript
jquery实现checkbox全选全不选的简单实例
2013/12/31 Javascript
js实现select跳转功能代码
2014/10/22 Javascript
Javascript代码实现仿实例化类
2015/04/03 Javascript
解决JavaScript数字精度丢失问题的方法
2015/12/03 Javascript
Javascript技术栈中的四种依赖注入详解
2016/02/23 Javascript
基于touch.js手势库+zepto.js插件开发图片查看器(滑动、缩放、双击缩放)
2016/11/17 Javascript
vue的Virtual Dom实现snabbdom解密
2017/05/03 Javascript
基于vue-cli3+typescript的tsx开发模板搭建过程分享
2020/02/28 Javascript
微信小程序基于高德地图API实现天气组件(动态效果)
2020/10/22 Javascript
[00:27]DOTA2战队VP、Secret贺新春
2018/02/11 DOTA
python时间日期函数与利用pandas进行时间序列处理详解
2018/03/13 Python
解决python报错MemoryError的问题
2018/06/26 Python
python用BeautifulSoup库简单爬虫实例分析
2018/07/30 Python
python基于socket实现的UDP及TCP通讯功能示例
2019/11/01 Python
Pytorch之卷积层的使用详解
2019/12/31 Python
python爬虫学习笔记之pyquery模块基本用法详解
2020/04/09 Python
Python3内置函数chr和ord实现进制转换
2020/06/05 Python
keras load model时出现Missing Layer错误的解决方式
2020/06/11 Python
python使用matplotlib绘制折线图的示例代码
2020/09/22 Python
python3实现语音转文字(语音识别)和文字转语音(语音合成)
2020/10/14 Python
美国婚礼装饰和活动用品批发供应商:Event Decor Direct
2018/10/12 全球购物
Trip.com澳大利亚:在线旅行社
2019/12/01 全球购物
日语翻译个人求职的自我评价
2013/10/14 职场文书
个性大学生自我评价
2013/12/04 职场文书
大学校运会广播稿
2014/02/03 职场文书
研究生毕业自我鉴定范文
2014/03/27 职场文书
岗位说明书怎么写
2014/07/30 职场文书
表扬通报怎么写
2015/01/16 职场文书
紫日观后感
2015/06/05 职场文书
浅谈MySQL中的六种日志
2022/03/23 MySQL