解決vue跨域axios非同步通信

来源:https://www.cnblogs.com/lianjy/archive/2019/04/17/10721374.html
-Advertisement-
Play Games

在項目中,常常需要從後端獲取數據內容。特別是在前後端分離的時候,前端進行了工程化部署,跨域請求成了一個前端必備的技能點。好在解決方案很多。 在vue中,在開發中,當前使用較多的是axios進行跨域請求數據,但不少人遇到如下問題: 非同步通信,無法同步執行 無法集中管理 不便閱讀 還未請求成功就調轉了 ...


在項目中,常常需要從後端獲取數據內容。特別是在前後端分離的時候,前端進行了工程化部署,跨域請求成了一個前端必備的技能點。好在解決方案很多。
在vue中,在開發中,當前使用較多的是axios進行跨域請求數據,但不少人遇到如下問題:

  • 非同步通信,無法同步執行
  • 無法集中管理
  • 不便閱讀
  • 還未請求成功就調轉了
  • then裡面的邏輯越來越繁雜

以往的網路請求的寫法如下:

// main.js

// 引入axios
import axios from 'axios'
Vue.prototype.$axios = axios;
// vue頁面中的使用

// get
let url = '地址'
this.$axios.get(url,{
  params:{} // 參數信息
})
  .then((res) => {
    // 成功後執行語句
  })
  .catch((err) =>{
    // 網路中斷或失敗執行語句
  })

// post
let url = '地址'
this.$axios.post(url,{
  // 參數信息
})
  .then((res) => {
    // 成功後執行語句
  })
  .catch((err) =>{
    // 網路中斷或失敗執行語句
  })

或許在目前的過程中非同步能夠更好的解決用戶體驗感,先載入後彈出。但總有那麼一個場景我們需要大量的內容進行處理,而且前後有明顯的順序執行的關係,那麼非同步通信可能會對你造成不必要的問題。所以,解決運用async/await解決非同步通信問題

main.js旁邊新建http.js文件

// http.js

引入axios
import axios from 'axios'

var http = {
  // get 請求
  get: function(url,params){
    return new Promise((resolve,reject) => {
      axios.get(url,{
        params:params
      })
        .then((response) =>{
          resolve(response.data)
        })
        .catch((error) => {
          reject( error )
        })
    })
  }
  // post 請求
  post: function(url,params){
    return new Promise((resolve,reject) => {
      axios.post(url,params)
      .then((response) => {
        resolve( response.data )
      })
      .catch((error) => {
        reject( error )
      })
    })
  }
}

export default http

併在main.js入口引入

// 引入http請求
import http from './http.js'
Vue.prototype.$http = http

現在就可以在頁面中使用了

// 在vue中使用

// get
async login () {
  let url = '地址'
  let params = {} // 參數
  let res = await this.$http.get(url,params)
}
// post
async login () {
  let url = '地址'
  let params = {} // 參數
  let res = await this.$http.post(url,params)
}

async 放在方法前面
await 放在$http前面就OK了

單詞示意:
async:非同步。
await:等待。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 選擇性較低的列是否適合加索引? 索引選擇性等於列中不重覆(distinct)的行數量(也叫基數),與記錄總數的比值。範圍在0 1之間。數值越大,索引越快。 例如主鍵是唯一的,不重覆的,所以選擇性=1。 常見的選擇性較低的列,例如是否熱門,要不1,要不0。選擇性等於2/記錄總數,所以是非常低的。 ...
  • 3 、redis的5種數據類型及相應命令 redis不區分命令大小寫。 string 512m 一個散列類型鍵可包含至多232-1個欄位 一個列表類型鍵最多能容納232-1個元素 一個集合類型鍵最多能容納232-1個元素 3.1、一些實用的基礎命令 keys pattern exists key 返 ...
  • 網上的教程有很多,基本上大同小異。但是安裝軟體有時就可能因為一個細節安裝失敗。我也是綜合了很多個教程才安裝好的,所以本教程可能也不是普遍適合的。 安裝環境:win7 1、下載zip安裝包: MySQL8.0 For Windows zip包下載地址:https://dev.mysql.com/dow ...
  • 對Sql細節優化 在sql查詢中為了提高查詢效率,我們常常會採取一些措施對查詢語句進行sql優化,下麵總結的一些方法,有需要的可以參考參考。 1.對查詢進行優化,應儘量避免全表掃描,首先應考慮在 where 及 order by 涉及的列上建立索引。 2.應儘量避免在 where 子句中對欄位進行 ...
  • 插入的方式一: 語法: insert into 表名(欄位)values(值); 特點: 1.要求表明括弧里的屬性和values括弧里的屬性一致或相容 2、欄位的個數和順序不一定與原始表中的欄位個數和順序一致 3.加入表中有null值,解決方案如下, ① 欄位和值都省了,全部不寫 ②在添加時,欄位寫 ...
  • No Network Security Config specified, using platform defaultI/System.out: org.apache.http.conn.HttpHostConnectException: Connection to http://192.168. ...
  • IconFont的使用 Iconfont-國內功能很強大且圖標內容很豐富的矢量圖標庫,提供矢量圖標下載、線上存儲、格式轉換等功能。阿裡巴巴體驗團隊傾力打造,設計和前端開發的便捷工具. https://www.iconfont.cn/ IOS使用 IOS可以直接使用單個icon(svg,png)。也可 ...
  • 原理:由於textView是繼承自UIScrollview,所以會有ContentSize屬性。所以可以通過文字內容的高度(也就是ContentSize)的高度和textView的高度之間的差值,設置內邊距,就相當於把內容居中了。 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...