解决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 相关文章推荐
从零开始学习jQuery (二) 万能的选择器
Oct 01 Javascript
jQuery之排序组件的深入解析
Jun 19 Javascript
动态添加删除表格行的js实现代码
Feb 28 Javascript
自己编写的支持Ajax验证的JS表单验证插件
May 15 Javascript
jQuery制作图片旋转效果
Feb 02 Javascript
javascript流程控制语句集合
Sep 18 Javascript
vue2中的keep-alive使用总结及注意事项
Dec 21 Javascript
深入浅析JS中的严格模式
Jun 04 Javascript
基于Bootstrap和JQuery实现动态打开和关闭tab页的实例代码
Jun 10 jQuery
基于JS实现简单滑块拼图游戏
Oct 12 Javascript
开发Node CLI构建微信小程序脚手架的示例
Mar 27 Javascript
nuxt+axios实现打包后动态修改请求地址的方法
Apr 22 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
PHP学习之PHP表达式
2006/10/09 PHP
如何判断php数组的维度
2013/06/10 PHP
PHP用strstr()函数阻止垃圾评论(通过判断a标记)
2013/09/28 PHP
Php无限级栏目分类读取的实现代码
2014/02/19 PHP
CI使用Tank Auth转移数据库导致密码用户错误的解决办法
2014/06/12 PHP
typecho插件编写教程(二):写一个新插件
2015/05/28 PHP
详谈PHP编码转换问题
2015/07/28 PHP
PHP实现百度人脸识别
2019/05/06 PHP
Laravel框架实现即点即改功能的方法分析
2019/10/31 PHP
PHP vsprintf()函数格式化字符串操作原理解析
2020/07/14 PHP
JS getStyle获取最终样式函数代码
2010/04/01 Javascript
游览器中javascript的执行过程(图文)
2012/05/20 Javascript
javaScript 计算两个日期的天数相差(示例代码)
2013/12/27 Javascript
jQuery实现的Div窗口震动效果实例
2015/08/07 Javascript
全面解析Bootstrap表单使用方法(表单控件状态)
2015/11/24 Javascript
JS判断当前页面是否在微信浏览器打开的方法
2015/12/08 Javascript
JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
2016/01/26 Javascript
利用JS实现点击按钮后图片自动切换的简单方法
2016/10/24 Javascript
AngularJS的脏检查深入分析
2017/04/22 Javascript
原生js轮播特效
2017/05/18 Javascript
vue2.0模拟锚点的实例
2018/03/14 Javascript
vue中的provide/inject的学习使用
2018/05/09 Javascript
Vue页面骨架屏的实现方法
2018/05/22 Javascript
利用JS动态生成隔行换色HTML表格的两种方法
2018/10/09 Javascript
Node.js 使用axios读写influxDB的方法示例
2018/10/26 Javascript
[01:14:35]DOTA2上海特级锦标赛B组资格赛#1 Alliance VS Fnatic第一局
2016/02/26 DOTA
Python的类实例属性访问规则探讨
2015/01/30 Python
Python3爬虫学习之爬虫利器Beautiful Soup用法分析
2018/12/12 Python
python实现IOU计算案例
2020/04/12 Python
pycharm中选中一个单词替换所有重复单词的实现方法
2020/11/17 Python
StubHub新西兰:购买和出售你的门票
2019/04/22 全球购物
The North Face官方旗舰店:美国著名户外品牌
2020/09/28 全球购物
蔬菜基地的创业计划书
2014/01/06 职场文书
书香校园活动方案
2014/02/28 职场文书
学校办公室主任岗位职责
2015/04/01 职场文书
运动会通讯稿100字
2015/07/20 职场文书