就像一个好的歌手可以同时作词作曲,想使用JavaScript体验从数据库到浏览器前后端同时开发的快感。
于是一个后端使用node,前端可以同时部署到移动端和微信小程序上的聊天机器人就此诞生。
初步构想:
移动端——使用Vue.js开发;
小程序——使用开源框架mpvue复用移动端代码;
服务端——使用koa2开发node服务。
项目虽小,五脏俱全。最终希望达到效果,只改变shell中的一行命令就能实现前后端的启动和不同平台上的运行。
为了实现这些想法所遇到的问题:
一、通过一条命令构建不同平台项目
这个问题可以交给webpack来完成。
小程序构建的webpack配置可以直接使用mpvue-cli的配置,里面会用到了一些vue转小程序与样式自适应的webpack loader 和 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)。两个平台的表现效果都还不错。
五、后台开发
koa是express的升级,在commonjs规范之外引入了es6的一些新语法,并对请求与响应做了优化。node的开发从express到koa的过渡还算比较平缓。将后端的启动脚本也一同在npm script中配置好,再使用npm run all插件就可以同时启动前后端了。
五、其他
1. 项目里尝试使用时间处理库 day.js ,轻量级,很不错;
2. 百度的 echarts 插件移动端的表现很好,但 echarts for wx 在小程序的表现有点差强人意;
3. 语义识别接口调用 OLAMI 开放平台;
4. 使用 Gulp 压缩node代码。
至此,一个使用node服务且同时支持移动端与小程序的聊天机器人技术层面已基本实现,JS从云到端的理想触手可及,但坑非踩过不知深,从开发到部署的过程中还会遇到各种各样的坑。希望本文能对大家有所帮助~
Github地址:聊天机器人
最后附效果图:
转载请注明出处。