vue中用什么来发送请求

vue中,需要使用vue-resource、axios等插件来发送请求。axios是一个基于Promise的HTTP请求客户端,用来发送请求,也是vue2.0官方推荐的,同时不再对vue-resource进行更新和维护。

vue中用什么来发送请求

本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。

Vue——发送http请求详解

1)vue本身不支持发送AJAX请求,需要使用vue-resource、axios等插件实现。

2) axios是一个基于Promise的HTTP请求客户端,用来发送请求,也是vue2.0官方推荐的,同时不再对vue-resource进行更新和维护。

使用axios发送AJAX请求

立即学习“前端免费学习笔记(深入)”;

1、安装axios并引入

1)npm的方式: $ npm install axios -S  或 cnpm install axios -S

2)bower的方式:$ bower install axios

3)cdn的方式:

2、如何引入使用axios

安装其他插件的时候,可以直接在 main.js 中引入并 Vue.use(),但是 axios 并不能 use,只能每个需要发送请求的组件中即时引入

为了解决这个问题,有两种开发思路,

一是在引入 axios 之后,修改原型链

二是结合 Vuex,封装一个 aciton

方案一:改写原型链

首先在 main.js 中引入 axios

import axios from 'axios'Vue.prototype.$http= axios

登录后复制

在组件中发送http请求

this.$http.post('/user',{name: 'xiaoming'})this.$http({method: 'post',url: '/user',data: {name: 'xiaoming'}})//发送get请求this.$http.get('/user?ID=12345') .then(res=> { console.log(response); }) .catch(err=> { console.log(error); });this.$http.get('/user',{params:{ID:12345}}) .then(res=> { console.log(response); }) .catch(err=> { console.log(error); });//发送post请求this.$http.post('/user',{name: 'xiaoming'}) .then(res=> { console.log(res) }) .catch(err=> { console.log(err)});

登录后复制

 3、封装axios进行调用

/****   request.js   ****/// 导入axiosimport axios from 'axios'// 使用element-ui Message做消息提醒import { Message} from 'element-ui';//1. 创建新的axios实例,const service = axios.create({  // 公共接口--这里注意后面会讲  baseURL: '',  // 超时时间 单位是ms,这里设置了3s的超时时间  timeout: 3 * 1000})// 2.请求拦截器service.interceptors.request.use(config => {  //发请求前做的一些处理,数据转化,配置请求头,设置token,设置loading等,根据需求去添加  config.data = JSON.stringify(config.data); //数据转化,也可以使用qs转换  console.log('请求拦截器中',config)  config.headers = {    'Content-Type':'application/x-www-form-urlencoded' //配置请求头  }  //注意使用token的时候需要引入cookie方法或者用本地localStorage等方法,推荐js-cookie  // const token = getCookie('名称');//这里取token之前,你肯定需要先拿到token,存一下  // if(token){  //   config.params = {'token':token} //如果要求携带在参数中  //   config.headers.token= token; //如果要求携带在请求头中  // }  return config}, error => {  console.log('错误')  Promise.reject(error)})// 3.响应拦截器service.interceptors.response.use(response => {  //接收到响应数据并成功后的一些共有的处理,关闭loading等  return response}, error => {  console.log('error',error)  /***** 接收到异常响应的处理开始 *****/  if (error && error.response) {    // 1.公共错误处理    // 2.根据响应码具体处理    switch (error.response.status) {      case 400:        error.message = '错误请求'        break;      case 401:        error.message = '未授权,请重新登录'        break;      case 403:        error.message = '拒绝访问'        break;      case 404:        error.message = '请求错误,未找到该资源'        // window.location.href = "/"        break;      case 405:        error.message = '请求方法未允许'        break;      case 408:        error.message = '请求超时'        break;      case 500:        error.message = '服务器端出错'        break;      case 501:        error.message = '网络未实现'        break;      case 502:        error.message = '网络错误'        break;      case 503:        error.message = '服务不可用'        break;      case 504:        error.message = '网络超时'        break;      case 505:        error.message = 'http版本不支持该请求'        break;      default:        error.message = `连接错误${error.response.status}`    }  } else {    // 超时处理    if (JSON.stringify(error).includes('timeout')) {      Message.error('服务器响应超时,请刷新当前页')    }    Message.error('连接服务器失败')  }  Message.error(error.message)  /***** 处理结束 *****/  //如果不需要错误处理,以上的处理过程都可省略  return Promise.resolve(error.response)})//4.导入文件export default service

登录后复制

/****   http.js   ****/// 导入封装好的axios实例import request from './request'const http ={  /**   * methods: 请求   * @param url 请求地址   * @param params 请求参数   */  get(url,params){    const config = {      method: 'get',      url:url    }    if(params) config.params = params    return request(config)  },  post(url,params){    console.log(url,params)    const config = {      method: 'post',      url:url    }    if(params) config.data = params    return request(config)  },  put(url,params){    const config = {      method: 'put',      url:url    }    if(params) config.params = params    return request(config)  },  delete(url,params){    const config = {      method: 'delete',      url:url    }    if(params) config.params = params    return request(config)  }}//导出export default http

登录后复制

import http from './http'///** *  @parms resquest 请求地址 例如:http://197.82.15.15:8088/request/... *  @param '/testIp'代表vue-cil中config,index.js中配置的代理 */// let resquest = ""// get请求export function getListAPI(resquest,params){  return http.get(`${resquest}/getList.json`,params)}// post请求export function postFormAPI(resquest,params){  console.log('发送post请求')  return http.post(`${resquest}`,params)}// put 请求export function putSomeAPI(resquest,params){  return http.put(`${resquest}/putSome.json`,params)}// delete 请求export function deleteListAPI(resquest,params){  return http.delete(`${resquest}/deleteList.json`,params)}

登录后复制

 解决Vue跨域问题:

vue中用什么来发送请求

解决方法:在脚手架中的config下的index.js中

在 dev 的 proxyTable 对象中添加这些属性

// Paths    assetsSubDirectory: 'static',    assetsPublicPath: '/',    proxyTable: {      "/api":{        target:"https://xin.yuemei.com/V603/channel/getScreenNew/",//接口域名        changeOrigin:true,//是否跨域        pathRewrite:{          "^/api":""//重写为空,这个时候api就相当于上面target接口基准地址        }      }    },

登录后复制

然后请求这里用axios请求
请求的时候前缀api就相当于基准地址了

axios.post("/api").then(res => {      console.log(res);      this.data = res.data.data; }); //如果有参数请求 axios.post("/api?key=111").then(res => {      console.log(res);      this.data = res.data.data; });

登录后复制

配置完记得重跑一下项目(切记)

想要发送Ajax请求 通过两种方式 

一:通过XHR对象 

请求行:

method:post 或get  url:请求地址

请求头:

host:主机地址

cookie
content-type:请求体内容

请求体:

响应行:status

响应头:多个响应头

响应体:

json/图片/css/js/html

二:通过fetch函数

【相关推荐:vue.js教程】

以上就是vue中用什么来发送请求的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2940586.html

(0)
上一篇 2025年3月11日 21:46:11
下一篇 2025年1月4日 02:56:45

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • vue-resource和vuex有什么区别

    vue-resource和vuex的区别:1、vue-resource是一个用于处理HTTP请求的插件,而Vuex是一个专为Vue.js应用程序开发的状态管理库;2、从Vue2.0开发,vue-resource不再更新,而vuex继续更新。…

    2025年3月11日
    200
  • vue里data为什么要用return返回数据

    原因:不使用return包裹的数据会在项目的全局可见,会造成变量污染;而使用return包裹后数据中变量只在当前组件中生效,不会影响其他组件。 本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。 官方: 当一个组…

    2025年3月11日
    200
  • vue怎么反转数组

    vue中可以利用“v-for”指令和计算属性来反转数组,语法“”和“computed:{reverseDIV(){return this.items.reverse()}}”。 本教程操作环境:windows7系统、vue2.9.6版,DE…

    2025年3月11日
    200
  • vue合并两个对象的方法是什么

    在vue中,可以利用“Object.assign()”方法来合并两个对象,该方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象,它将返回目标对象,语法为“Object.assign(对象1, 对象2)”。 本教程操作环境:wind…

    2025年3月11日
    200
  • 一个vue页面由什么组成

    一个vue页面由三部分组成:1、template标签包裹的界面展示代码(HTML代码);2、script标签包裹的业务实现代码(js脚本代码);3、style标签包裹的界面布局代码(css样式代码)。 本教程操作环境:windows7系统、…

    2025年3月11日
    200
  • vue中骨架屏是什么

    在vue中,骨架屏就是在页面数据尚未加载前先给用户展示出页面的大致结构,直到请求数据返回后再渲染页面,补充进需要显示的数据内容;骨架屏可以理解为是当数据还未加载进来前,页面的一个空白版本,一个简单的关键渲染路径。 本教程操作环境:windo…

    2025年3月11日 编程技术
    200
  • vue路由有哪两种模式

    vue路由的两种模式:1、hash模式,其原理是onhashchange事件,可以在window对象上监听这个事件;2、history模式,可利用“history.pushState”的API来完成URL跳转。 本教程操作环境:window…

    2025年3月11日 编程技术
    200
  • vue构建需要哪些目录

    vue构建需要的目录:1、build(构建脚本目录);2、config(项目配置目录);3、node_modules(项目依赖模块目录);4、src;5、static(静态资源目录);6、components(组件目录)等等。 本教程操作环…

    2025年3月11日 编程技术
    200
  • vue的核心是什么

    vue有两大核心:1、数据驱动,也就是数据的双向绑定,让视图(DOM)的内容随着数据的改变而改变;2、组件化系统,可实现扩展HTML元素,封装可用的代码。 本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。 vu…

    2025年3月11日
    200
  • vue中的ajax一般放在哪个生命周期中

    vue中的ajax请求一般放在“created”周期中,好处:1、能更快获取到服务端数据,减少页面loading时间;2、有助于一致性,因为ssr不支持beforeMount、mounted钩子函数。 本教程操作环境:windows7系统、…

    2025年3月11日
    200

发表回复

登录后才能评论