​●●●

大家好,

我是一名刚步入社会的有志青年开发者。

在校学了三年的后端开发,没想到刚步入公司干起了前端工作,华丽的转变让我有点猝不及防,谁让我辣么优秀!

趁着头发茂密,让我们步入正题!

很有幸进入公司就参与了项目的开发,项目的前端是采用的Vue和Element框架,我刚拿到公司封装之后的Vue的脚手架翻了翻,瞬间感觉对不起老大,我不配当你小弟,请原谅我猜不透你的心思。何以解忧,唯有度娘。

熟悉了那么一个星期,让我最钦佩的是调用后端接口这块封装的代码,使用的时候仿佛像在写java调用类的静态方法一样,就像这样AppController.create,有人肯定会问你的参数是不是让狗吃了,兄台白慌,听哥说完,你不看完我咋提高阅读量,下面请不要随地吐痰。

作为前端开发,避免不了与后台接口打交道,经常要去接口文档或者访问swagger网址查看接口详情,就导致代码和查看接口之间来回切换。年轻手速快记性好的请随意。

接口联调的时候如何一眼就能知道该调哪个接口和传哪些参数很重要,有助于开发的效率。如果有一种将接口信息植入到前端项目里,调用的时候它还能提示你调哪个方法,参数还能一目了然的方式,那就美滋滋了。然而在这里,你赚大了。

框架的灵魂在于它的设计思想,在这里仅传授设计思想,不然就像我最近写论文一样半天憋不出俩字写个猴年马月。

前面写的有点啰嗦了,

下面那就开始掉头发吧。

首先了解一下前端管理后台接口的架构流程,技术选型后端要使用swagger接口管理,前端vue使用vuex状态管理,解析swagger需要用到Handlebars模板编译和fs文件解析。

1、使用Swagger。

首先要想设计好这块,必须要求后台服务引入swagger插件,它就是一款让你更好的书写API文档的框架。如果你公司没有用它就lower了,我不是求针对,我就是针对你。

2、解析Swagger和生成actions。

后台服务启动后访问http://ip:port/v2/api-docs得到一个JSON字符串,首先将字符串解析成JSON对象,然后获取对象中tags数组和paths对象,tags里面包含每个类的名称和描述,paths里面包含接口的访问url、请求方式、接口描述、所属tags和参数描述。通过遍历tags从paths对象里面获取每个接口的详细信息,最后通过Handlebars编译成指定格式的js文件。每个类对应一个文件,文件内容是一个对象,里面包含一个actions对象,这个actions对象含有一个类里面的所有接口详细信息。说到这里,估计有的小伙伴已经眼神已经迷离了。总结一下,网上一大堆,不抄你赖谁,写好喝咖啡,王者带你飞。

3、vuex装饰actions。

我们都知道vuex里面action是支持异步操作的。这里我们对上述每个生成的acitons文件进行装饰,装饰的内容包括每个接口请求前、发送请求和请求之后对state数据的改变。装饰之后生成新的actions。最后交给store进行管理。这里的发送请求其实就是调用封装好之后的axios的方法。

4、组件使用vuex辅助函数。

vuex里面有四个辅助函数mapState()、mapGetters、mapMutations和mapActions,这里仅使用mapState和mapActions即可满足需求,其中mapState用来获取请求接口的loading情况,通过判断loading和v-loading结合可以提高用户体验。mapActions将保存在store的actions映射到组件当中,在组件中直接可以通过this来调用actions完成网络请求。

5、抽离封装组件。

我们不能在每次调用接口都使用辅助函数来一遍吧,所以需要抽离一个公共组件,在这个公共组件里可以封装一个统一的方法调用mapActions生成的函数,通过传递action函数名和参数来完成接口的调用,组件里面还可以封装一些对请求错误处理的公共方法。如果想要更简单的,可以封装一个全局的方法dispatch进行调用。

6、混入(mixins)使用。

Vue里面有一个很好的混入功能,混入组件拥有自己的生命周期,可以将一些公共的数据放在组件里。这里我们可以通过混入将之前抽离封装的组件。在需要接口调用时,直接可以this.xxx进行调用。

最后达到的效果:

在vue组件中使用this.dispatch(AppController.create,{...args}),返回值为接口调用的返回值。

关于vue接口管理的设计就到这里,下一篇我将讲述如何使用react或rn高效管理调用后端接口。

对于vuex和redux不熟的童鞋

赶紧去学

别在这听我胡扯。

关于作者:卜壮,普元前端开发工程师,负责Mobile 8.0项目管理平台前端部分。熟悉ReactNative,目前正在学习Vue,大前端技术探求者。

关于EAWorld:微服务,DevOps,数据治理,移动架构原创技术分享。

vuex 编译项目_俺咋能看懂公司前端项目?相关推荐

  1. 项目管理有妙招,看懂你的项目健康状态和完整度

    项目管理的黑洞 有不少非软件工程科班专业的老板表示,真的不知道如何管理和把控软件项目的管理,因为那些编程的专业和编程语言他又不懂. 也有不少新晋的开发管理者,从以前负责系统的核心开发人员晋升到团队管理 ...

  2. sip 时序图_时序图怎么看_教你如何看懂时序图 - 什么是时序图_时序图怎么看_教你如何看懂时序图...

    时序图怎么看_教你如何看懂时序图 操作时序永远使用是任何一片IC芯片的最主要的内容.一个芯片的所有使用细节都会在它的官方器件手册上包含.所以使用一个器件事情,要充分做好的第一件事就是要把它的器件手册上 ...

  3. nginx配置vue项目500_一个Nginx部署多个vue前端项目总结

    摘要: 近来接手了一个二次开发的前后端分离模式的项目,其中在前端项目的部署上需要让2个前端项目都部署到一个IP地址和端口下,那么我们这里就要用到Nginx了,接下来我们看看如何在一个Nginx下部署2 ...

  4. VUE项目学习(一):搭建VUE前端项目

    VUE项目学习(一):搭建VUE前端项目 1.安装node.js环境 (1)下载node.js,下载地址为:https://nodejs.org/en/ (2)按照默认选项安装node,检查安装版本 ...

  5. android git提交整个项目_使用子模块和子树来管理 Git 项目 | Linux 中国

    使用子模块和子树来帮助你管理多个存储库中共有的子项目.https://linux.cn/article-12244-1.html作者:Manaswini Das译者:Xiaobin.Liu 如果你参与 ...

  6. nuxt解决首屏加载慢问题_一个 Node 脚本让你的前端项目加载速度飞起来

    写在最前面 我的原创什么声明变成什么鬼了-- 前言 随着前端三大框架的盛行,越来越多的前后端分离项目在服务器上跑了起来,随之而来,开发者也慢慢发现了这种开发模式所带来的弊端,其中之一就是首屏加载速度特 ...

  7. 语言线性拟合线对称_文科生都能看懂的机器学习教程:梯度下降、线性回归、逻辑回归...

    [新智元导读]虽然在Coursera.MIT.UC伯克利上有很多机器学习的课程,包括吴恩达等专家课程已非常经典,但都是面向有一定理科背景的专业人士.本文试图将机器学习这本深奥的课程,以更加浅显易懂的方 ...

  8. em算法 实例 正态分布_人人都能看懂的EM算法推导

    ↑ 点击蓝字 关注极市平台作者丨August@知乎(已授权)来源丨https://zhuanlan.zhihu.com/p/36331115编辑丨极市平台 极市导读 EM算法到底是什么,公式推导怎么去 ...

  9. 2021年网络赚钱方法以及网络兼职赚钱项目_做知识付费平台的公司有哪些,互联网知识付费的项目

    微信上知识付费项目怎么样?小白如何在一年内操作知识付费狂赚25万! 知识付费其实已存在多年,由知识付费演变而来的项目也有好几种.余果云课堂之前发布过相关内容,据相关统计,2020年,中国人在知识付费领 ...

最新文章

  1. 开放源码,华为鸿蒙HarmonyOS 2.0来了
  2. SZOJ 142 钦定
  3. 【分享送书】NGUI全面实践教程V3.8.2 活动开始了!!
  4. 皮一皮:傻傻分不清,这究竟是教室还是...
  5. 高斯混合模型Gaussian Mixture Model (GMM)——通过增加 Model 的个数,我们可以任意地逼近任何连续的概率密分布...
  6. Redis-12Redis 流水线( pipeline )
  7. 求指定范围内的所有素数C++代码实现
  8. [导入]防止你的日志页被人iframe
  9. 权限管理-SpringSecurity介绍
  10. 关于ping命令的工作原理
  11. ACM-Maximum Tape Utilization Ratio
  12. 复习:线性表——双链表、循环链表
  13. 设计模式练习:Decorate模式
  14. python挖矿脚本_利用公共WiFi挖矿的Python脚本(注:仅作研究使用)
  15. 芒果TV广告投放的展现样式!芒果TV广告投放如何收费?
  16. iPad商标门--苹果败诉,,之后是和解么???
  17. rails相当于java中的什么_Rails中的ERB中的%,%=,%#和-%有什么区别?
  18. 我们整天忙忙碌碌,像一群群没有灵魂的苍蝇
  19. 【Qt】 Fractal Designer 5.2 Bug Report
  20. 【今日荐文】一本开源的程序员快速成长秘笈---康德胜

热门文章

  1. linux查询关键词上下行_Linux:从文件中搜索关键字并显示行数(cat,grep函数)
  2. 主题mysql_主题数据库(SubjectBase)
  3. python:绑定方法和非绑定方法
  4. 用python-opencv实现简单的车牌定位
  5. python之请求报文对比(假定最多二维字典)
  6. mysql索引查2遍_mysql索引优化查询
  7. escape mysql_MySQL中ESCAPE关键字的用法详解
  8. Flask学习 视频网站搭建(Python-flask视频网站搭建)
  9. python PyQt5 QPixmap()控件
  10. python distutils模块(貌似是用来打包发布自定义python包的)