开发一个可以同时部署到移动端和微信小程序上的聊天机器人。
初步构想:
移动端
使用Vue.js开发。
小程序
使用美团开源框架mpvue复用移动端代码集成到小程序。
一般来说,根据官方文档将两个平台分开来写,重复代码直接复制粘贴基本上就可以实现需求。但有一天忽然心血来潮,想把两个项目合二为一,只在Power Shell里改变一条命令,就能构建出适应不同平台的产品,于是就有了这个项目。
Github地址:聊天机器人
接下来说一说为了实现这个想法所遇到的几个问题:
一、通过一条命令构建不同平台项目
这个问题可以交给webpack来完成。
小程序构建的webpack配置可以直接使用mpvue-cli的配置,里面用到了一些美团实现的vue转小程序的webpack和postcss插件,直接下载安装就可以了。
移动端的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方法实现页面跳转。
(现在美团已造好新轮子——mpvue-router-patch)
四、参数传递
web开发经常会通过在url上附带参数来传递,但小程序里是不允许这种方式。所以就开心(wu nai)地去使用 vuex 吧,统一状态管理听起来就高大上~
参阅文档上手vuex应该没什么问题,但vuex略微遗憾的是页面刷新会使状态参数丢失。为了使项目体验更佳我使用了 vuex + localstorege 的方式来存储参数(微信也原生实现了缓存数据的wx.setStorage)。两个平台的表现效果都还不错。
五、其他
1. 项目里尝试使用了 day.js 这个刚刚发布的时间处理库,轻量级,很不错。
2. 百度的echarts插件移动端的表现很好,但最近发布的echarts for wx在小程序的表现有点差强人意。
至此,一个同时支持移动端与小程序的聊天机器人技术层面基本实现,还有其它不足之处有待完善,github还会继续commits~
附效果图:
移动端页面
小程序页面
转载请注明出处。













网友评论
使用开发者头条 App 搜索 356481 即可订阅《u480465的独家号》