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

网站建设与实现的要求与务html企业网站模板

网站建设与实现的要求与务,html企业网站模板,discuz仿wordpress,.net网站开发实站在vue项目中,通常使用axios与后台进行数据交互,axios是一款基于promise封装的库, axios特性: 1、axios 是一个基于promise的HTTP库,支持promise所有的API 2、浏览器端/node端(服务器端)都可以…

在vue项目中,通常使用axios与后台进行数据交互,axios是一款基于promise封装的库,

axios特性:

1、axios 是一个基于promise的HTTP库,支持promise所有的API
2、浏览器端/node端(服务器端)都可以使用,浏览器中创建XMLHttpRequests
3、支持请求/响应拦截器
4、它可以转换请求数据和响应数据,并对响应回来的内容自动转换成 JSON类型的数据
5、批量发送多个请求
6、安全性更高,客户端支持防御XSRF

使用场景

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

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

import axios from 'axios'
import {serialize} from '@/util'
import {getStore} from '@/util/store'
import NProgress from 'nprogress' // progress bar
import errorCode from '@/const/errorCode'
import router from '@/router/router'
import {Message, MessageBox} from 'element-ui'
import 'nprogress/nprogress.css'
import qs from 'qs'
import store from '@/store' // progress bar style
axios.defaults.timeout = 60000  // 默认值是30000
// 返回其他状态吗
axios.defaults.validateStatus = function (status) {return status >= 200 && status <= 500 // 默认的
}
// 跨域请求,允许保存cookie
axios.defaults.withCredentials = true
// NProgress Configuration
NProgress.configure({showSpinner: false
})// HTTPrequest拦截
axios.interceptors.request.use(config => {NProgress.start() // start progress barconst TENANT_ID = getStore({name: 'tenantId'})const isToken = (config.headers || {}).isToken === falseconst token = store.getters.access_tokenif (token && !isToken) {config.headers['Authorization'] = 'Bearer ' + token// token}if (TENANT_ID) {config.headers['TENANT-ID'] = TENANT_ID // 租户ID}// headers中配置serialize为true开启序列化if (config.method === 'post' && config.headers.serialize) {config.data = serialize(config.data)delete config.data.serialize}if (config.method === 'get') {config.paramsSerializer = function (params) {return qs.stringify(params, {arrayFormat: 'repeat'})}}return config
}, error => {return Promise.reject(error)
})// HTTPresponse拦截
axios.interceptors.response.use(res => {console.log('res',res)NProgress.done()const status = Number(res.status) || 200const message = res.data.msg || errorCode[status] || errorCode['default']// 后台定义 424 针对令牌过去的特殊响应码if (status === 424) {MessageBox.confirm('令牌状态已过期,请点击重新登录', '系统提示', {confirmButtonText: '重新登录',cancelButtonText: '取消',type: 'warning'}).then(() => {store.dispatch('LogOut').then(() => {// 刷新登录页面,避免多次弹框window.location.reload()})}).catch(() => {});return}// 处理 500 网络异常if (status === 500) {Message({message: '服务器异常!',type: 'error'})return Promise.reject(new Error(message))}if (status !== 200 || res.data.code === 1) {Message({message: message,type: 'error'})return Promise.reject(new Error(message))}return res
}, error => {// 处理 503 网络异常if (error.response.status === 503) {Message({message: error.response.data.msg,type: 'error'})}NProgress.done()return Promise.reject(new Error(error))
})export default axios
http://www.yayakq.cn/news/765814/

相关文章:

  • 网站交互方式网站 所有权
  • 网站收录量怎么提升电子商务网站租用服务器费用
  • 网站的网页设计毕业设计wordpress logo设置
  • 中山网站开发公司做网站公司做网站公司有哪些
  • 做酱菜网站电子产品论坛都有哪些
  • 上海网站制作官网嵌入式软件开发工程师培训
  • 微网站用什么做的网站开发研究手段有哪些
  • 叫别人做网站要注意什么河北邢台特色美食
  • 怎么做网站主页设计什么都能搜到的浏览器
  • 网站制作与建设教程下载专业定制网站开发公司
  • 东光网站建设徐州制作企业网站
  • 比较好的网页模板网站网站公司建设网站首页
  • 工信部网站域名备案查询系统杭州哪里做网站好
  • 简述网页建站流程苏州园科生态建设集团网站
  • 在哪租用网站erp软件怎么用
  • 大通网站建设温州建设诚信评价网站公示
  • 做商品网站数据库有哪些凡科互动抽奖
  • 珠海正规网站制作系统中山seo排名
  • 2017做网站赚钱安卓优化大师官网下载
  • 升级网站注册公司场地有什么要求
  • 网站建设与管理 第2版哈尔滨门户网站建站
  • 旅游网站建设的概念wordpress 编辑权限
  • 有微信公众号怎么做微网站免费留电话的广告
  • 网站建设流行技术餐饮连锁网站建设
  • 佛山个性化网站搭建wordpress中文显示成问号
  • 珠海企业网站搭建制作辽阳县住房和城乡建设局网站
  • wordpress建站门户php网站修改代码
  • 长沙诚信做网站知识网站有哪些
  • 华为网站开发电脑优化大师下载安装
  • 网站建设设计文档模板下载网站建设投入及费用