在vue中,需要使用vue-resource、axios等外掛來傳送請求。axios是一個基於Promise的HTTP請求使用者端,用來傳送請求,也是vue2.0官方推薦的,同時不再對vue-resource進行更新和維護。
本教學操作環境:windows7系統、vue2.9.6版,DELL G3電腦。
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的方式:<script src=」https://unpkg.com/axios/dist/axios.min.js」></script>
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 ****/ // 匯入axios import 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跨域問題:
解決方法:在腳手架中的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中用什麼來傳送請求的詳細內容,更多請關注TW511.COM其它相關文章!