微信小程序开发之一个同时支持移动端与小程序的聊天机器人
白羽 2018-07-18 来源 :网络 阅读 1489 评论 0

摘要:本文将带你了解微信小程序开发之一个同时支持移动端与小程序的聊天机器人,希望本文对大家学微信有所帮助。


就像一个好的音乐人可以同时作词作曲,想使用JavaScript体验从数据库到浏览器这样前后端同时开发的快感。

于是一个后端使用node,前端可以同时部署到移动端和微信小程序上的聊天机器人就此诞生。

初步构想:

移动端——使用Vue.js开发;

小程序——使用开源框架mpvue复用移动端代码;

服务端——使用koa2开发node服务。

项目虽小,五脏俱全。由于前后端都使用JS,虽然项目实际前后端分离但写在一起。并且为了同时支持移动端与小程序,还是需要一些底层方法的抽象和封装。最终希望达到,只改变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地址:聊天机器人


本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之微信频道!


本文由 @白羽 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved