应公司需求,着手开发一个同时部署到移动端和微信小程序上产品需求相同的聊天机器人。
于是初步构想:
移动端
使用Vue.js开发。
小程序
使用美团点评的开源框架mpvue复用移动端代码集成到小程序。
一般来说,根据官方文档将两个端分开来写,重复代码直接复制粘贴基本上就可以实现公司的需求。但一天忽然心血来潮,想把两个项目合二为一,只在Power Shell里改变一条命令,就能构建出适应不同平台的项目,于是就有了这个东西。
Git地址先贴为敬:Github聊天机器人
接下来说一说为了实现这个骚想法所遇到的几个问题:
一、如何通过一条命令来构建不同平台项目
解决方法是把这个任务交给webpack来完成。webpack作为强大的前端模块化开发工具“用过都说好”,没用过的赶紧去用一下吧。
小程序构建的webpack配置可以直接使用mpvue-cli的配置,里面用到了一些美团实现的vue文件转小程序文件的webpack插件,下载安装就可以了。
移动端的webpack配置可以参考vue-cli的配置,熟悉webpack的话可以自己来写。当然也可以使用我的项目里的配置。
构建不同项目时只需要使用npm命令启用不同的webpack配置文件就行。(手动修改项目package.json里的npm script)。
遇到的第一个问题就这样愉快地解决了。
二、http请求的封装
以往Vue项目的http请求都是使用axios插件完成的,而小程序里的http请求必须调用微信的原生API——wx.request。因此为了同时支持两个平台,项目里需要将http请求封装并且能够自动识别调用。
解决方法是使用vue的全局混入(mixins)方式。混入全局变量this.service通过判断是否是浏览器环境(if(window)),而指向不同的http模块。
有了这种识别混入方式,基本上就可以通过将小程序的原生API在浏览器环境下重新全部实现一次而完成全部代码复用。
三、页面跳转
vue项目中使用vue-router跳转页面已经十分成熟了,但是mpvue的文档中却写明由于小程序页面的注册方式奇特而不支持vue-router的使用。
但是有了上面的这种混入方式,还是可以实现曲线救国,在项目中引入vue-router。
解决方法是全局混入this.router变量,同时封装小程序里的wx.navigateTo和web端的location.href方法实现页面跳转。
四、页面间参数的传递
web开发经常会通过在url上附带参数来传递,但小程序里是不允许这样的。解决方法是就去开心(wu nai)地去使用vuex吧,统一状态管理听起来就高大上~
参阅文档上手vuex应该没什么问题,但vuex略微遗憾的是页面刷新会使状态参数丢失。为了使项目体验更佳我使用了vuex+localstorege的方式来存储参数(微信也原生实现了缓存数据的wx.setStorage)。这种方法两个端表现效果都还不错。
五、其他
1. 项目里尝试使用了 day.js 这个刚刚发布的时间处理库,轻量级,很不错。
2. 百度的echarts插件移动端的表现很好,但最近发布的echarts for wx在小程序的表现有点差强人意。
至此,一个同时支持移动端与小程序的聊天机器人技术层面基本实现,还有其它不足之处有待完善,github还会继续commits~
转载请注明出处。
附效果图: