axios进阶实践之利用最优雅的方式写ajax请求


Posted in Javascript onDecember 20, 2017

前言

ajax相信不用过多介绍了,作者坚信可以用配置解决的问题,请勿硬编码,下面话不多说了,来一看看详细的介绍吧。

姊妹篇 jQuery进阶:用最优雅的方式写ajax请求

axios是Vue官方推荐的ajax库, 用来取代vue-resource。更多详细的基础知识可以参考这篇文章:https://3water.com/article/109444.htm

优点:

  • 增加一个ajax接口,只需要在配置文件里多写几行就可以
  • 不需要在组件中写axios调用,直接调用api方法,很方便
  • 如果接口有调整,只需要修改一下接口配置文件就可以
  • 统一管理接口配置

1. content-type配置

// filename: content-type.js
module.exports = {
 formData: 'application/x-www-form-urlencoded; charset=UTF-8',
 json: 'application/json; charset=UTF-8'
}

2. api 配置

// filename: api-sdk-conf.js
import contentType from './content-type'
export default {
 baseURL: 'http://192.168.40.231:30412',
 apis: [
 {
  name: 'login',
  path: '/api/security/login?{{id}}',
  method: 'post',
  contentType: contentType.formData,
  status: {
  401: '用户名或者密码错误'
  }
 }
 ]
}

3. request.js 方法

// request.js
import axios from 'axios'
import qs from 'qs'
import contentType from '@/config/content-type'
import apiConf from '@/config/api-sdk-conf'
var api = {}
// render 函数用来渲染路径上的变量, 算是一个微型的模板渲染工具
// 例如render('/{{userId}}/{{type}}/{{query}}', {userId:1,type:2, query:3})
// 会被渲染成 /1/2/3
function render (tpl, data) {
 var re = /{{([^}]+)?}}/
 var match = ''
 while ((match = re.exec(tpl))) {
 tpl = tpl.replace(match[0], data[match[1]])
 }
 return tpl
}
// fire中的this, 会动态绑定到每个接口上
function fire (query = {}, payload = '') {
 // qs 特别处理 formData类型的数据
 if (this.contentType === contentType.formData) {
 payload = qs.stringify(payload)
 } 
 // 直接返回axios实例,方便调用then,或者catch方法
 return axios({
 method: this.method,
 url: render(this.url, query),
 data: payload,
 headers: {
  contentType: this.contentType
 }
 })
}
apiConf.apis.forEach((item) => {
 api[item.name] = {
 url: apiConf.baseURL + item.path,
 method: item.method,
 status: item.status,
 contentType: item.contentType,
 fire: fire
 }
})
export default api

4. 在组件中使用

import api from '@/apis/request'
...
  api.login.fire({id: '?heiheihei'}, {
  username: 'admin',
  password: 'admin',
  namespace: '_system'
  })
...

浏览器结果:

Request URL:http://192.168.40.231:30412/api/security/login??heiheihei
Request Method:POST
Status Code:200 OK
Remote Address:192.168.40.231:30412
Referrer Policy:no-referrer-when-downgrade
POST /api/security/login??heiheihei HTTP/1.1
Host: 192.168.40.231:30412
Connection: keep-alive
Content-Length: 47
Accept: application/json, text/plain, */*
Origin: http://localhost:8080
contentType: application/x-www-form-urlencoded; charset=UTF-8
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36
Content-Type: application/x-www-form-urlencoded
Referer: http://localhost:8080/
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8
username=admin&password=admin&namespace=_system

5. 更多

有个地方我不是很明白,希望懂的人可以给我解答一下

如果某个组件中只需要login方法,但是我这样写会报错。

import {login} from '@/apis/request'

这样写的前提是要在request.js最后写上

export var login = api.login
    

但是这是我不想要的,因为每次增加一个接口,这里都要export一次, 这不符合开放闭合原则,请问有什么更好的方法吗?

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
用jscript实现列出安装的软件列表
Jun 18 Javascript
javascript下判断一个对象是否具有指定名称的属性的的代码
Jan 11 Javascript
几个有趣的Javascript Hack
Jul 24 Javascript
Jquery动态更改一张位图的src与Attr的使用
Jul 31 Javascript
js使用正则实现ReplaceAll全部替换的方法
Jul 18 Javascript
javascript实现字符串反转的方法
Feb 05 Javascript
ECMAScript6中Map/WeakMap详解
Jun 12 Javascript
JS+CSS实现美化的下拉列表框效果
Aug 11 Javascript
学习JavaScript正则表达式
Nov 13 Javascript
JS字典Dictionary类定义与用法示例
Feb 01 Javascript
Element图表初始大小及窗口自适应实现
Jul 10 Javascript
Ajax实现页面无刷新留言效果
Mar 24 Javascript
vue.js $refs和$emit 父子组件交互的方法
Dec 20 #Javascript
jQuery进阶实践之利用最优雅的方式如何写ajax请求
Dec 20 #jQuery
详解Vue 中 extend 、component 、mixins 、extends 的区别
Dec 20 #Javascript
vue.js vue-router如何实现无效路由(404)的友好提示
Dec 20 #Javascript
详解vue mixins和extends的巧妙用法
Dec 20 #Javascript
canvas轨迹回放功能实现
Dec 20 #Javascript
jQuery实现动态控制页面元素的方法分析
Dec 20 #jQuery
You might like
用PHP实现小型站点广告管理(修正版)
2006/10/09 PHP
PHP fopen 读取带中文URL地址的一点见解
2012/09/25 PHP
深入php处理整数函数的详解
2013/06/09 PHP
php顺序查找和二分查找示例
2014/03/27 PHP
Zend Framework实现具有基本功能的留言本(附demo源码下载)
2016/03/22 PHP
iis 7下安装laravel 5.4环境的方法教程
2017/06/14 PHP
深入理解JavaScript系列(8) S.O.L.I.D五大原则之里氏替换原则LSP
2012/01/15 Javascript
javascript游戏开发之《三国志曹操传》零部件开发(四)用地图块拼成大地图
2013/01/23 Javascript
js/jQuery简单实现选项卡功能
2014/01/02 Javascript
JQEasy-ui在IE9以下版本中二次加载的问题分析及处理方法
2014/06/23 Javascript
jQuery使用height()获取高度需要注意的地方
2014/12/13 Javascript
jQuery获得包含margin的outerWidth和outerHeight的方法
2015/03/25 Javascript
jquery中表单 多选框的一种巧妙写法
2015/09/06 Javascript
jQuery使用$.ajax进行即时验证的方法
2015/12/08 Javascript
js实现html table 行,列锁定的简单实例
2016/10/13 Javascript
self.attachevent is not a function的解决方法
2017/04/04 Javascript
全面解析Node.js 8 重要功能和修复
2017/06/02 Javascript
如何在JavaScript中优雅的提取循环内数据详解
2019/03/04 Javascript
vue使用video.js进行视频播放功能
2019/07/18 Javascript
js实现微信聊天界面
2020/08/09 Javascript
Python实现115网盘自动下载的方法
2014/09/30 Python
python通过ftplib登录到ftp服务器的方法
2015/05/08 Python
python3下使用cv2.imwrite存储带有中文路径图片的方法
2018/05/10 Python
Python开发的十个小贴士和技巧及长常犯错误
2018/09/27 Python
谈一谈基于python的面向对象编程基础
2019/05/21 Python
Python Django 简单分页的实现代码解析
2019/08/21 Python
python 下 CMake 安装配置 OPENCV 4.1.1的方法
2019/09/30 Python
python实现连续变量最优分箱详解--CART算法
2019/11/22 Python
基于Python的自媒体小助手---登录页面的实现代码
2020/06/29 Python
canvas绘制树形结构可视图形的实现
2020/04/03 HTML / CSS
Mybag美国/加拿大:英国奢华包包和名牌手袋网站
2020/02/16 全球购物
顶岗实习接收函
2014/01/09 职场文书
商铺门前三包责任书
2014/07/25 职场文书
2014年销售工作总结范文
2014/12/01 职场文书
《兰兰过桥》教学反思
2016/02/20 职场文书
HTML基础详解(下)
2021/10/16 HTML / CSS