解决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 相关文章推荐
Extjs在exlipse中设置自动提示的方法
Apr 07 Javascript
解决js数据包含加号+通过ajax传到后台时出现连接错误
Aug 01 Javascript
使用FlexiGrid实现Extjs表格效果方法分享
Dec 16 Javascript
详解JavaScript的AngularJS框架中的表达式与指令
Mar 05 Javascript
url中的特殊符号有什么含义(推荐)
Jun 17 Javascript
Avalonjs 实现简单购物车功能(实例代码)
Feb 07 Javascript
详解在Angular项目中添加插件ng-bootstrap
Jul 04 Javascript
基于JavaScript实现幸运抽奖页面
Jul 05 Javascript
angular6.0开发教程之如何安装angular6.0框架
Jun 29 Javascript
浅谈Vue.js 关于页面加载完成后执行一个方法的问题
Apr 01 Javascript
vue项目中openlayers绘制行政区划
Dec 24 Vue.js
JS前端使用Canvas快速实现手势解锁特效
Sep 23 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.MVC的模板标签系统(四)
2006/09/05 PHP
php图片的二进制转换实现方法
2014/12/15 PHP
php轻松实现文件上传功能
2016/03/03 PHP
PHP Echo字符串的连接格式
2016/03/07 PHP
php数组函数array_walk用法示例
2016/05/26 PHP
php性能分析之php-fpm慢执行日志slow log用法浅析
2016/10/17 PHP
基于PHP常用文件函数和目录函数整理
2017/08/17 PHP
DEFER怎么用?
2006/07/01 Javascript
jQuery插件Validate实现自定义表单验证
2016/01/18 Javascript
jQuery ajax方法传递中文时出现中文乱码的解决方法
2016/07/25 Javascript
JS动态的把左边列表添加到右边的实现代码(可上下移动)
2016/11/17 Javascript
SVG描边动画
2017/02/23 Javascript
jQuery实现radio第一次点击选中第二次点击取消功能
2017/05/15 jQuery
你有必要知道的10个JavaScript难点
2017/07/25 Javascript
jQuery实现滚动效果
2017/11/17 jQuery
vue2.0 实现导航守卫的具体用法(路由守卫)
2018/05/17 Javascript
js数组去重的方法总结
2019/01/18 Javascript
微信小程序wx.request的简单封装
2019/11/13 Javascript
Python命令行参数解析模块getopt使用实例
2015/04/13 Python
在Python中编写数据库模块的教程
2015/04/29 Python
dataframe 按条件替换某一列中的值方法
2019/01/29 Python
python SQLAlchemy的Mapping与Declarative详解
2019/07/04 Python
自定义实现 PyQt5 下拉复选框 ComboCheckBox的完整代码
2020/03/30 Python
python 动态绘制爱心的示例
2020/09/27 Python
python3 使用ssh隧道连接mysql的操作
2020/12/05 Python
HTML5是什么 HTML5是什么意思 HTML5简介
2012/10/26 HTML / CSS
针对HTML5的Web Worker使用攻略
2015/07/12 HTML / CSS
银行职员思想汇报
2013/12/31 职场文书
上班玩游戏检讨书
2014/02/07 职场文书
年终总结会主持词
2014/03/25 职场文书
庆六一文艺汇演活动方案
2014/08/26 职场文书
2014和解协议书范文
2014/09/15 职场文书
见习报告格式范文
2014/11/08 职场文书
伏羲庙导游词
2015/02/09 职场文书
辞职信标准格式
2015/02/27 职场文书
消防演习感想
2015/08/10 职场文书