解决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 相关文章推荐
收藏一些不常用,但是有用的代码
Mar 12 Javascript
Lazy Load 延迟加载图片的 jQuery 插件
Feb 06 Javascript
jquery 插件实现瀑布流图片展示实例
Apr 03 Javascript
详解JavaScript的回调函数
Nov 20 Javascript
使用 stylelint检查CSS_StyleLint
Apr 28 Javascript
详解jQuery中的deferred对象的使用(一)
May 27 Javascript
分类解析jQuery选择器
Nov 23 Javascript
JavaScript实现事件的中断传播和行为阻止方法示例
Jan 20 Javascript
jqGrid翻页时数据选中丢失问题的解决办法
Feb 13 Javascript
详解如何使用 vue-cli 开发多页应用
Dec 16 Javascript
JavaScript利用键盘码控制div移动
Mar 19 Javascript
详解JavaScript作用域 闭包
Jul 29 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
星际初学者游戏中永远要做的事
2020/03/04 星际争霸
mysql建立外键
2006/11/25 PHP
PHP程序员最常犯的11个MySQL错误小结
2010/11/20 PHP
php若干单维数组遍历方法的比较
2011/09/20 PHP
Laravel实现用户注册和登录
2015/01/23 PHP
php 数组处理函数extract详解及实例代码
2016/11/23 PHP
弹出模态框modal的实现方法及实例
2017/09/19 PHP
浅谈laravel orm 中的一对多关系 hasMany
2019/10/21 PHP
通过PHP的Wrapper无缝迁移原有项目到新服务的实现方法
2020/04/02 PHP
动态加载js的几种方法
2006/10/23 Javascript
ASP SQL防注入的方法
2008/12/25 Javascript
javascript 语法基础 想学习js的朋友可以看看
2009/12/16 Javascript
firefox下frameset取不到值的解决方法
2010/09/06 Javascript
基于jquery实现图片广告轮换效果代码
2011/07/07 Javascript
jquery使用jxl插件导出excel示例
2014/04/14 Javascript
JavaScript中伪协议 javascript:使用探讨
2014/07/18 Javascript
开源的javascript项目Kissy介绍
2014/11/28 Javascript
JS数组的常见用法实例
2015/02/10 Javascript
jquery 插件实现瀑布流图片展示实例
2015/04/03 Javascript
详解Immutable及 React 中实践
2018/03/01 Javascript
vue 监听键盘回车事件详解 @keyup.enter || @keyup.enter.native
2018/08/25 Javascript
javascript中UMD规范的代码推演
2018/08/29 Javascript
Layer UI表格列日期格式化及取消自动填充日期的实现方法
2020/05/10 Javascript
ssm+vue前后端分离框架整合实现(附源码)
2020/07/08 Javascript
Postman参数化实现过程及原理解析
2020/08/13 Javascript
Node.JS如何实现JWT原理
2020/09/18 Javascript
Python中每次处理一个字符的5种方法
2015/05/21 Python
Python爬虫常用小技巧之设置代理IP
2018/09/13 Python
python+splinter自动刷新抢票功能
2018/09/25 Python
Python秒算24点实现及原理详解
2019/07/29 Python
Django ORM 聚合查询和分组查询实现详解
2019/08/09 Python
介绍一下SQL注入攻击的种类和防范手段
2012/02/18 面试题
行政专员求职信范文
2014/05/03 职场文书
童年读书笔记
2015/06/26 职场文书
治理商业贿赂工作总结
2015/08/10 职场文书
军训心得体会范文(2016最新篇)
2016/01/11 职场文书