美文网首页让前端飞程序员
一个同时支持移动端与小程序的聊天机器人

一个同时支持移动端与小程序的聊天机器人

作者: 最美不过快青 | 来源:发表于2018-06-02 00:06 被阅读346次

开发一个可以同时部署到移动端和微信小程序上的聊天机器人。

初步构想:

移动端

使用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:感谢分享!已推荐到《开发者头条》:https://toutiao.io/posts/jir4g5 欢迎点赞支持!
    使用开发者头条 App 搜索 356481 即可订阅《u480465的独家号》
  • 6545d8491407:在吗大佬,可以问你些问题吗?在线等挺急,加你微信之类的也可以
    6545d8491407:@最美不过快青 加我微信一下可以吗大佬 loveasukasong 我的小程序根据你的方法想配置h5 但是配置不出来,你能帮我看看怎么回事吗
    最美不过快青:@会潜水的小纽扣 什么问题?
  • 60f31575940e:厉害,最近正在学如何将vue.js项目转化成小程序

本文标题:一个同时支持移动端与小程序的聊天机器人

本文链接:https://www.haomeiwen.com/subject/ratcsftx.html