当前位置: 首页 > news >正文

自建网站迁移普宁做网站

自建网站迁移,普宁做网站,国际原油价格最新实时消息,网店装修店面09-axios 前言首先简单了解什么是Axios?以上完成后就可以使用了 前言 我们接着上一篇文章 08-路由地址的数据获取 来讲。 下一篇文章 10-vuex在Vue中的导入与配置 首先简单了解什么是Axios? Axios是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端…

09-axios

  • 前言
  • 首先简单了解什么是Axios?
    • 以上完成后就可以使用了

前言

我们接着上一篇文章 08-路由地址的数据获取 来讲。


下一篇文章 10-vuex在Vue中的导入与配置

首先简单了解什么是Axios?

Axios是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,本质上也是对原生XHR的封装,只不过它是Promise的实现版本,符合最新的ES规范。

关于axios的特点,可以查看axios中文文档,还可以了解一下axios, ajax和fetch的详细比较内容。

接下来开始安装axios,在项目目录下执行npm i axios(不同的node版本,成功后的提示不同)

在这里插入图片描述

安装成功后进行引入,在项目目录下src文件夹里创建新的utils文件夹,然后,在文件夹里创建axios.js

/utils/axios.js

/axios/index.js

/utils/request.js

// 1、引入axios内容
import axios from 'axios'// 2、设置请求默认内容
// 请求服务器地址
axios.defaults.baseURL = 'https://www.xxxx.com:8080'
// 跨域请求是否提供凭据信息(cookie、HTTP认证及客户端SSL证明等),也可以简单的理解为,当前请求为跨域类型时是否在请求中协带cookie。
axios.defaults.withCredentials = true
// 请求头中X-Requested-With字段值为XMLHttpRequest
axios.defaults.headers['X-Requested-With'] = 'XMLHttpRequest'
// 请求头中携带token值
axios.defaults.headers['token'] = localStorage.getItem('token') || ''
// 使用post请求时,发送的数据类型(Content-Type)为 application/json
axios.defaults.headers.post['Content-Type'] = 'application/json'// axios使用拦截器,我们下面会讲一下拦截器的定义
axios.interceptors.response.use(res => {// 服务器返回值非正常情况下执行的代码if (typeof res.data !== 'object') {alert('服务器异常!')return Promise.reject(res)}if (res.data.resultCode != 200) { // 浏览器状态码不为200(正常)if (res.data.message) alert(res.data.message)  //判断是否有错误信息,有则打印错误信息if (res.data.resultCode == 416) { // 浏览器状态码为416(未登录)alert('未登录,请先登录!')}return Promise.reject(res.data)}// 服务器返回值正常情况下执行的代码return res.data
})
// 导出axios 实例
export default axios
// 1、引入axios内容
import axios from 'axios'// 2、设置请求默认内容
// 请求服务器地址
axios.defaults.baseURL = 'https://www.xxxx.com:8080'
// 跨域请求是否提供凭据信息(cookie、HTTP认证及客户端SSL证明等),也可以简单的理解为,当前请求为跨域类型时是否在请求中协带cookie。
axios.defaults.withCredentials = true
// 请求头中X-Requested-With字段值为XMLHttpRequest
axios.defaults.headers['X-Requested-With'] = 'XMLHttpRequest'
// 请求头中携带token值
//axios.defaults.headers['token'] = localStorage.getItem('token') || ''
// 使用post请求时,发送的数据类型(Content-Type)为 application/json
axios.defaults.headers.post['Content-Type'] = 'application/json'axios.interceptors.request.use(config => {config.headers['token'] = localStorage.getItem('token') || '';return config
})// axios使用拦截器,我们下面会讲一下拦截器的定义
axios.interceptors.response.use(res => {// 服务器返回值非正常情况下执行的代码// if (typeof res.data !== 'object') {//   alert('服务器异常!')//   return Promise.reject(res)// }// if (res.data.resultCode != 200) { // 浏览器状态码不为200(正常)//   if (res.data.message) alert(res.data.message)  //判断是否有错误信息,有则打印错误信息//   if (res.data.resultCode == 416) { // 浏览器状态码为416(未登录)//     alert('未登录,请先登录!')//   }//   return Promise.reject(res.data)// }// 服务器返回值正常情况下执行的代码return res.data
})
// 导出axios 实例
export default axios

关于拦截器

​ 如果我们使用中需要统一处理所有 http 请求和响应, 就需要使用 axios 拦截器。

使用拦截器的原因:

​ 若出现请求数多的情况下,我们将会用到 axios 的一个API:拦截器。
​ 页面发送http请求,很多情况我们要对请求和其响应进行特定的处理,
​ 如果每个请求都附带后端返回的token,我们需要在拿到response之前loading动画的展示等。

拦截器的分类:

​ 拦截器分为 请求(request)拦截器和 响应(response)拦截器。

以上完成后就可以使用了

接下来以get请求为例,使用方式如下:

this.axios.get(url).then(res => {//请求成功,触发then中的函数console.log(res)  }).catch(error =>//请求失败,触发catch中的函数 可省略console.log(error))

某商城的API接口:http://backend-api-01.newbee.ltd/api/v1/index-infos

<template><div id="app"><ul><li v-for="(good, index) in list" :key="index">{{ good }}</li></ul></div>
</template><script>import axios from "./utils/axios";
export default {data() {return {list: [],};},mounted(){axios.get("http://backend-api-01.newbee.ltd/api/v1/index-infos").then(res => {console.log(res);this.list = res.data.hotGoodses})}
};
</script>

请求结果自行判断

关于post请求方式与get类似,不同点在于地址url和参数params分开传递,使用方式如下:

axios.post(url, params).then(res => {//请求成功,触发then中的函数console.log(res)  }).catch(error =>//请求失败,触发catch中的函数 可省略console.log(error))
http://www.yayakq.cn/news/199693/

相关文章:

  • 小皮搭建本地网站网络服务遇到问题请稍后再试吧
  • 网站水军怎么做品牌建设的工作
  • 怎么改网站模块域名注册后怎么建网站
  • 外贸家具网站甘肃城乡建设局安全质量网站
  • 网站开发融资计划ui设计与制作
  • 河南焦作有做网站开发的公司吗wordpress 演示数据 导入
  • 安徽网站建设的基本步骤海南公司注册网站
  • 门户网站搭建软件这样制作公司网站
  • 万家建设有限公司网站快印店网站建设84wzjs
  • 把网站做进微信公众号华为游戏中心
  • 企业门户网站建设报价搜索引擎优化案例
  • 网站内链有什么用网络广告的优缺点
  • 自学建网站做网站优化手机软件怎么制作
  • 县级门户网站建设的报告WordPress登录ip
  • 设计素材网站线上毕节建设公司网站
  • 自行车网站模板天津专业制作网站
  • 网站开发 图片库网站做优化效果怎么样
  • 网站空间合同海南注册公司流程和费用
  • 做教育的网站有哪些图书馆门户网站建设总结
  • 网站建设公司douyanet网站建设专业培训
  • 网站建设歺金手指排名13长沙景点图片
  • 一个网站有多少页面wordpress安装demo
  • 昆明市住房和城乡建设局网站上看的大学 建网站
  • 驻马店 网站建设佛山seo按效果付费
  • 网站建设维保免费内容网页电子书在线阅读器wordpress
  • 经营网站建设网站备案费用
  • 没有外贸网站 如果做外贸杨庄网站建设
  • 分销网站有哪些全国企业名单大全
  • 如何把做的网站与域名连接不上住房城乡建设部办公厅网站
  • iis禁止通过ip访问网站网站首页分类怎么做的