欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue+axios+promise實際開發(fā)用法詳解

 更新時間:2018年10月15日 09:11:43   作者:羊先生  
這篇文章主要介紹了vue+axios+promise實際開發(fā)用法詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

axios它是基于promise的http庫,可運行在瀏覽器端和node.js中,然后作者尤雨溪也是果斷放棄了對其官方庫vue-resource的維護,直接推薦axios庫,小編我也是從vue-resource轉(zhuǎn)換過來的,差別說不來,我們講一下axios在實際開發(fā)中的用法

axios特點

1.從瀏覽器中創(chuàng)建 XMLHttpRequests
2.從 node.js 創(chuàng)建 http 請求
3.支持 Promise API
4.攔截請求和響應(yīng) (就是有interceptor)
5.轉(zhuǎn)換請求數(shù)據(jù)和響應(yīng)數(shù)據(jù)
6.取消請求
7.自動轉(zhuǎn)換 JSON 數(shù)據(jù)
8.客戶端支持防御 XSRF

安裝axios和qs

npm i axios --save
npm i qs--save

創(chuàng)建項公共模塊API

我是用vue-cli創(chuàng)建的項目在src->util->api.js(公共請求模塊js)

引入axios和qs

import axios from 'axios'

有時候向后端發(fā)送數(shù)據(jù),后端無法接收,考慮使用qs模塊

import qs from 'qs'

判定開發(fā)模式

if (process.env.NODE_ENV == 'development') {  

  axios.defaults.baseURL = '/api';

}else if (process.env.NODE_ENV == 'debug') {  

  axios.defaults.baseURL = 'http://v.juhe.cn';

}else if (process.env.NODE_ENV == 'production') {  

  axios.defaults.baseURL = 'http://v.juhe.cn';

}

全局設(shè)置頭部信息

axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';

全局設(shè)置超時時間

axios.defaults.timeout = 10000;

請求路由攔截

在請求發(fā)出去之前,可以做一些判斷,看是否是合法用戶

axios.interceptors.request.use(function (config) {
  // 一般在這個位置判斷token是否存在
  return config;
  }, function (error) {
  // 對請求錯誤做些什么
  return Promise.reject(error);
});

響應(yīng)攔截

axios.interceptors.response.use(function (response){
   // 處理響應(yīng)數(shù)據(jù)
  if (response.status === 200) {      
    return Promise.resolve(response);    
  } else {      
    return Promise.reject(response);    
  }
  }, function (error){
  // 處理響應(yīng)失敗
  return Promise.reject(error);
});

封裝請求方法

使用ES6模塊化export導(dǎo)出import導(dǎo)入

在ES6前, 前端就使用RequireJS或者seaJS實現(xiàn)模塊化, requireJS是基于AMD規(guī)范的模塊化庫, 而像seaJS是基于CMD規(guī)范的模塊化庫, 兩者都是為了為了推廣前端模塊化的工具,現(xiàn)在ES6自帶了模塊化,不過現(xiàn)代瀏覽器對模塊(module)支持程度不同, 需要使用babelJS, 或者Traceur把ES6代碼轉(zhuǎn)化為兼容ES5版本的js代碼;

get請求

export function get(url, params){  
  return new Promise((resolve, reject) =>{    
    axios.get(url, {      
      params: params    
    }).then(res => {
      resolve(res.data);
    }).catch(err =>{
      reject(err.data)    
    })  
  });
}

post請求

export function post(url, params) {
  return new Promise((resolve, reject) => {
     axios.post(url, qs.stringify(params))
    .then(res => {
      resolve(res.data);
    })
    .catch(err =>{
      reject(err.data)
    })
  });
}

實際使用

在main.js中引入js

import {get,post} from './utils/api'
//將方法掛載到Vue原型上
Vue.prototype.get = get;
Vue.prototype.post = post;

配置請求環(huán)境

這里通過devServer請求代理

當(dāng)在請求過程中有/api字符串會自動轉(zhuǎn)換為目標(biāo)服務(wù)器地址(target)

devServer: {
  historyApiFallback: true,
  hot: true,
  inline: true,
  stats: { colors: true },
  proxy: {
   //匹配代理的url
   '/api': {
     // 目標(biāo)服務(wù)器地址
       target: 'http://v.juhe.cn',
       //路徑重寫
       pathRewrite: {'^/api' : ''},
       changeOrigin: true,
       secure: false,
      }
   },
  disableHostCheck:true
  }

這是請求聚合數(shù)據(jù)的接口為列子

this.get('/toutiao/index?type=top&key=秘鑰',{})
  .then((res)=>{
    if(res.error_code===0){
      resolve(res);
    }else{
      //這里拋出的異常被下面的catch所捕獲
      reject(error);
    }
  })
  .catch((err)=>{
    console.log(err)
  })

返回數(shù)據(jù)

使用promise

1.比如用戶想請求url1接口完后再調(diào)url2接口

  var promise = new Promise((resolve,reject)=>{
    let url1 = '/toutiao/index?type=top&key=秘鑰'
    this.get(url,{})
    .then((res)=>{
      resolve(res);
    })
    .catch((err)=>{
      console.log(err)
    })
  });
  promise.then((res)=>{
    let url2 = '/toutiao/index?type=top&key=秘鑰'
    this.get(ur2,{})
    .then((res)=>{
      //只有當(dāng)url1請求到數(shù)據(jù)后才會調(diào)用url2,否則等待
      resolve(res);
    })
    .catch((err)=>{
      console.log(err)
    })
  })

Promise對象

  • Promise有三種狀態(tài)
  • pending: 等待中,或者進(jìn)行中,表示還沒有得到結(jié)果
  • resolved: 已經(jīng)完成,表示得到了我們想要的結(jié)果,可以繼續(xù)往下執(zhí)行
  • rejected: 也表示得到結(jié)果,但是由于結(jié)果并非我們所愿,因此拒絕執(zhí)(用catch捕獲異常)

這三種狀態(tài)不受外界影響,而且狀態(tài)只能從pending改變?yōu)閞esolved或者rejected,并且不可逆(顧名思義承諾的后的東西怎么又能返回呢)。在Promise對象的構(gòu)造函數(shù)中,將一個函數(shù)作為第一個參數(shù)。而這個函數(shù),就是用來處理Promise的狀態(tài)變化

這里要注意,不管是then或者catch返回的都是一個新的Promise實例!而每個Primise實例都有最原始的Pending(進(jìn)行中)到Resolve(已完成),或者Pending(進(jìn)行中)到Reject(已失?。┑倪^程

Promise基本用法

Promise.all()用法

var p = Promise.all([p1, p2, p3]);

all()接受數(shù)組作為參數(shù)。p1,p2,p3都是Promise的實例對象,p要變成Resolved狀態(tài)需要p1,p2,p3狀態(tài)都是Resolved,如果p1,p2,p3至少有一個狀態(tài)是Rejected,p就會變成Rejected狀態(tài)

Promise.race()用法

var p = new Promise( [p1,p2,p3] )

只要p1、p2、p3之中有一個實例率先改變狀態(tài),p的狀態(tài)就跟著改變。那個率先改變的 Promise 實例的返回值,就傳遞給p的回調(diào)函數(shù),p的狀態(tài)就會改變Resolved狀態(tài)

Promise resolve()用法

Promise.resolve('foo')
// 等價于
new Promise(resolve => resolve('foo'))

有時需要將現(xiàn)有對象轉(zhuǎn)為Promise對象,Promise.resolve方法就起到這個作用.

Promise reject()用法

Promise.reject('foo')
// 等價于
new Promise(reject => reject('foo'))

Promise.reject(reason)方法也會返回一個新的 Promise 實例,該實例的狀態(tài)為rejected。但是Promise.reject()方法的參數(shù),會原封不動地作為reject的理由,變成后續(xù)方法的參數(shù)。這一點與Promise.resolve方法不一致。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 基于vue.js組件實現(xiàn)分頁效果

    基于vue.js組件實現(xiàn)分頁效果

    這篇文章主要為大家詳細(xì)介紹了基于vue.js組件實現(xiàn)分頁效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • 基于Vue實現(xiàn)微信小程序的圖文編輯器

    基于Vue實現(xiàn)微信小程序的圖文編輯器

    這篇文章主要介紹了基于Vue實現(xiàn)微信小程序的圖文編輯器,由于微信小程序不能使用常規(guī)的圖文編輯器(比如百度的UEditor )編輯新聞內(nèi)容之類的,所以用vue寫了個針對小程序用的圖文編輯器需要的朋友可以參考下
    2018-07-07
  • vue3如何使用vant-picker封裝省市二級聯(lián)動

    vue3如何使用vant-picker封裝省市二級聯(lián)動

    這篇文章主要介紹了vue3如何使用vant-picker封裝省市二級聯(lián)動,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue中的前端crypto.js加解密

    Vue中的前端crypto.js加解密

    這篇文章主要介紹了Vue中的前端crypto.js加解密問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 一文詳細(xì)聊聊vue3的defineProps、defineEmits和defineExpose

    一文詳細(xì)聊聊vue3的defineProps、defineEmits和defineExpose

    vue3官方文檔defineProps和defineEmits都是只能在scriptsetup中使用的編譯器宏,下面這篇文章主要給大家介紹了關(guān)于vue3的defineProps、defineEmits和defineExpose的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • vue?px轉(zhuǎn)rem配置詳解

    vue?px轉(zhuǎn)rem配置詳解

    這篇文章主要為大家介紹了vue?px轉(zhuǎn)rem配置,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • Vue之監(jiān)聽數(shù)據(jù)的原理詳解

    Vue之監(jiān)聽數(shù)據(jù)的原理詳解

    這篇文章主要為大家介紹了Vue之監(jiān)聽數(shù)據(jù)的原理,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助<BR>
    2021-11-11
  • vue項目多租戶環(huán)境變量的設(shè)置

    vue項目多租戶環(huán)境變量的設(shè)置

    本文主要介紹了vue項目多租戶環(huán)境變量的設(shè)置,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • VUE?el-table列表搜索功能純前端實現(xiàn)方法

    VUE?el-table列表搜索功能純前端實現(xiàn)方法

    Vue表搜索是指在Vue應(yīng)用中實現(xiàn)對表格數(shù)據(jù)的搜索功能,下面這篇文章主要給大家介紹了關(guān)于VUE?el-table列表搜索功能純前端實現(xiàn)的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • Vue請求JSON Server服務(wù)器數(shù)據(jù)的實現(xiàn)方法

    Vue請求JSON Server服務(wù)器數(shù)據(jù)的實現(xiàn)方法

    這篇文章主要介紹了Vue請求JSON Server服務(wù)器數(shù)據(jù)的實現(xiàn)方法,需要的朋友可以參考下
    2018-11-11

最新評論