suchen
HeimWeb-FrontendFront-End-Fragen und AntwortenWas nützt die Vue-Kapselung von Axios?

Vue-Kapselung von Axios kann die Codequalität verbessern und die Verwendung komfortabler machen. Die API von axios ist sehr benutzerfreundlich und Entwickler können sie problemlos direkt im Projekt verwenden. Mit zunehmender Projektgröße ist es jedoch erforderlich, bei jeder Initiierung einer HTTP-Anfrage Vorgänge wie das Festlegen eines Zeitlimits, das Festlegen von Anforderungsheadern usw. zu schreiben. Fehlerbehandlung usw. . Diese Art der sich wiederholenden Arbeit verschwendet nicht nur Zeit, sondern macht den Code auch überflüssig und schwierig zu warten. Um die Qualität unseres Codes zu verbessern, sollten wir Axios vor der Verwendung zweimal im Projekt kapseln, was die Arbeit erleichtern kann verwenden.

Was nützt die Vue-Kapselung von Axios?

Die Betriebsumgebung dieses Tutorials: Windows7-System, Vue3-Version, DELL G3-Computer. Axios Was ist Axios? Seit Vue2.0 hat Youda angekündigt, die offizielle Empfehlung von vue-resource abzubrechen und stattdessen axios zu empfehlen. Mittlerweile ist Axios für die meisten Vue-Entwickler zur ersten Wahl geworden.

Mit zunehmendem Umfang des Projekts werden jedoch bei jeder Initiierung einer HTTP-Anfrage diese Vorgänge wie das Festlegen des Zeitlimits, das Festlegen des Anforderungsheaders, das Bestimmen der zu verwendenden Anforderungsadresse basierend auf der Projektumgebung, die Fehlerbehandlung usw. , alles muss geschrieben werden Diese Art der Doppelarbeit verschwendet nicht nur Zeit, sondern macht den Code auch überflüssig und schwierig zu warten. Um die Qualität unseres Codes zu verbessern, sollten wir Axios zweimal im Projekt kapseln und dann verwenden Zum Beispiel:

axios('http://localhost:3000/data', {
  // 配置代码
  method: 'GET',
  timeout: 1000,
  withCredentials: true,
  headers: {
    'Content-Type': 'application/json',
    Authorization: 'xxx',
  },
  transformRequest: [function (data, headers) {
    return data;
  }],
  // 其他请求配置...}).then((data) => {
  // todo: 真正业务逻辑代码
  console.log(data);}, (err) => {
  // 错误处理代码  
  if (err.response.status === 401) {
  // handle authorization error
  }
  if (err.response.status === 403) {
  // handle server forbidden error
  }
  // 其他错误处理.....
  console.log(err);});

Wenn jede Seite ähnliche Anfragen sendet, muss einfach viel Konfiguration und Fehlerbehandlung geschrieben werden Es scheint zu umständlich

Zu diesem Zeitpunkt müssen wir Axios neu kapseln, um die Verwendung komfortabler zu machen

So kapseln Sie

Während der Kapselung müssen Sie einige Vereinbarungen mit dem Backend aushandeln, Header anfordern und Statuscodes angeben , Anforderungs-Timeout ... Schnittstellen-Anforderungspräfix festlegen: Abhängig von der Entwicklungs-, Test- und Produktionsumgebung müssen die Präfixe unterschieden werden

Anforderungsheader: Um bestimmte Dienste zu implementieren, müssen einige Parameter übertragen werden. Nur dann können Anforderungen ausgeführt werden gemacht werden (zum Beispiel: Mitgliedschaftsgeschäft)

Statuscode: Abhängig vom unterschiedlichen Status, der von der Schnittstelle zurückgegeben wird, können unterschiedliche Dienste ausgeführt werden. Dies muss mit dem Backend vereinbart werden.

Anforderungsmethode: Führen Sie eine Neukapselung basierend auf durch Get-, Post- und andere Methoden sind bequemer zu verwenden.

Request-Interceptor: Bestimmen Sie, auf welche Anforderungen gemäß den Einstellungen des Anforderungsheaders zugegriffen werden kann.

Response-Interceptor: Dieser Block basiert auf dem vom Backend zurückgegebenen Statuscode, um zu bestimmen Ausführung verschiedener Dienste

Legen Sie das Schnittstellenanforderungspräfix fest

Verwenden Sie Knotenumgebungsvariablen, um Entscheidungen zur Unterscheidung von Entwicklungs-, Test- und Produktionsumgebungen zu treffen

if (process.env.NODE_ENV === 'development') {
  axios.defaults.baseURL = 'http://dev.xxx.com'
} else if (process.env.NODE_ENV === 'production') {
  axios.defaults.baseURL = 'http://prod.xxx.com'
}
Beim lokalen Debuggen müssen Sie auch devServer in der vue.config konfigurieren. js-Datei zum Implementieren einer domänenübergreifenden

devServer: {
    proxy: {
      '/proxyApi': {
        target: 'http://dev.xxx.com',
        changeOrigin: true,
        pathRewrite: {
          '/proxyApi': ''
        }
      }
    }
  }

Anforderungsheader und Timeout-Zeit festlegen

In den meisten Fällen sind die Anforderungsheader festgelegt. Hier sind einige spezielle Anforderungsheader erforderlich Der Universal Requests Header als Basiskonfiguration. Wenn ein spezieller Anforderungsheader erforderlich ist, übergeben Sie den speziellen Anforderungsheader als Parameter, um die Grundkonfiguration zu überschreiben aufzurufen und verfügbar zu machen

const service = axios.create({
    ...
    timeout: 30000,  // 请求 30s 超时
	  headers: {
        get: {
          'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'
          // 在开发中,一般还需要单点登录或者其他功能的通用请求头,可以一并配置进来
        },
        post: {
          'Content-Type': 'application/json;charset=utf-8'
          // 在开发中,一般还需要单点登录或者其他功能的通用请求头,可以一并配置进来
        }
  },
})

Fügen Sie die gekapselte Methode in eine api.js-Datei ein

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

// post
// post请求
export function httpPost({
  url,
  data = {},
  params = {}
}) {
  return new Promise((resolve, reject) => {
    axios({
      url,
      method: 'post',
      transformRequest: [function (data) {
        let ret = ''
        for (let it in data) {
          ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'
        }
        return ret
      }],
      // 发送的数据
      data,
      // url参数
      params

    }).then(res => {
      resolve(res.data)
    })
  })
}

Sie können sie direkt auf der Seite aufrufen

import { httpGet, httpPost } from './http'
export const getorglist = (params = {}) => httpGet({ url: 'apps/api/org/list', params })

Auf diese Weise kann die API in Zukunft einheitlich verwaltet und geändert werden Muss nur in der api.js-Datei durchgeführt werden

Request Interceptor

Request Interceptor kann jeder Anfrage ein Token hinzufügen und ist nach der einheitlichen Verarbeitung einfach zu warten

// .vue
import { getorglist } from '@/assets/js/api'

getorglist({ id: 200 }).then(res => {
  console.log(res)
})

Response interceptor

Response interceptor kann Führen Sie nach Erhalt der Antwort eine Schicht aus, z. B. die Beurteilung des Anmeldestatus und der Autorisierung anhand des Statuscodes.

// 请求拦截器
axios.interceptors.request.use(
  config => {
    // 每次发送请求之前判断是否存在token
    // 如果存在,则统一在http请求的header都加上token,这样后台根据token判断你的登录情况,此处token一般是用户完成登录后储存到localstorage里的
    token && (config.headers.Authorization = token)
    return config
  },
  error => {
    return Promise.error(error)
  })

Zusammenfassung

Die einfache Kapselung von Axios ermöglicht es uns, ihren Charme zu schätzen Niemand Absoluter Standard, solange Ihr Paket Ihre Projektanforderungen erfüllt und einfach zu verwenden ist, ist es eine gute Paketlösung

[Verwandte Empfehlungen:

vuejs-Video-Tutorial

,

Web-Front-End-Entwicklung

]

Das obige ist der detaillierte Inhalt vonWas nützt die Vue-Kapselung von Axios?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
React: Die Kraft einer JavaScript -Bibliothek für die WebentwicklungReact: Die Kraft einer JavaScript -Bibliothek für die WebentwicklungApr 18, 2025 am 12:25 AM

React ist eine von Meta entwickelte JavaScript -Bibliothek zum Erstellen von Benutzeroberflächen, wobei der Kern die Komponentenentwicklung und die virtuelle Dom -Technologie ist. 1. Komponenten und Staatsmanagement: React verwaltet den Zustand durch Komponenten (Funktionen oder Klassen) und Hooks (wie Usestate), wodurch die Wiederverwendbarkeit und Wartung von Code verbessert wird. 2. Virtuelle DOM- und Leistungsoptimierung: Reagieren Sie durch virtuelles DOM effizient die reale DOM, um die Leistung zu verbessern. 3. Lebenszyklus und Haken: Hooks (wie die Verwendung von UseEffect) ermöglichen Funktionskomponenten, Lebenszyklen zu verwalten und Nebeneffektoperationen durchzuführen. V.

Reacts Ökosystem: Bibliotheken, Tools und Best PracticesReacts Ökosystem: Bibliotheken, Tools und Best PracticesApr 18, 2025 am 12:23 AM

Das React-Ökosystem umfasst staatliche Verwaltungsbibliotheken (z. B. Redux), Routing-Bibliotheken (z. B. Reactrouter), UI-Komponentenbibliotheken (wie Material-UI), Testwerkzeuge (wie Scherz) und Erstellung von Tools (z. B. Webpack). Diese Tools arbeiten zusammen, um Entwicklern dabei zu helfen, Anwendungen effizient zu entwickeln und zu pflegen, und die Effizienz der Code zu verbessern.

Reagieren und Frontendentwicklung: Ein umfassender ÜberblickReagieren und Frontendentwicklung: Ein umfassender ÜberblickApr 18, 2025 am 12:23 AM

React ist eine von Facebook entwickelte JavaScript -Bibliothek zum Erstellen von Benutzeroberflächen. 1. Es wird komponentierte und virtuelle DOM -Technologie verwendet, um die Effizienz und Leistung der UI -Entwicklung zu verbessern. 2. Die Kernkonzepte von React umfassen Komponentierungen, Staatsmanagement (wie Usestate und UseEffect) und das Arbeitsprinzip des virtuellen DOM. 3. In praktischen Anwendungen unterstützt React von der grundlegenden Komponentenwiedergabe bis hin zur erweiterten asynchronen Datenverarbeitung. 4. Häufige Fehler wie das Vergessen, Schlüsselattribute oder falsche Statusaktualisierungen hinzuzufügen, können durch ReactDevtools und Protokolle debuggen werden. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung von React.MEMO, Code -Segmentierung und Halten des Codes und die Aufrechterhaltung der Zuverlässigkeit

Die Kraft des Reagierens in HTML: Moderne WebentwicklungDie Kraft des Reagierens in HTML: Moderne WebentwicklungApr 18, 2025 am 12:22 AM

Die Anwendung von React in HTML verbessert die Effizienz und Flexibilität der Webentwicklung durch Komponentierungen und virtuelles DOM. 1) Die Reaktion der Komponentierung Die Idee unterteilt die Benutzeroberfläche in wiederverwendbare Einheiten, um das Management zu vereinfachen. 2) Virtuelle DOM -Optimierungsleistung, minimieren Sie DOM -Operationen durch Differungsalgorithmus. 3) Die JSX -Syntax ermöglicht das Schreiben von HTML in JavaScript, um die Entwicklungseffizienz zu verbessern. 4) Verwenden Sie den Usestate -Hook, um den Status zu verwalten und dynamische Inhaltsaktualisierungen zu realisieren. 5) Optimierungsstrategien umfassen die Verwendung von React.Memo und Usecallback, um unnötiges Rendern zu verringern.

Das Verständnis der Hauptfunktion von React: Die Frontend -PerspektiveDas Verständnis der Hauptfunktion von React: Die Frontend -PerspektiveApr 18, 2025 am 12:15 AM

Zu den Hauptfunktionen von React gehören komponentiertes Denken, Staatsmanagement und virtuelles DOM. 1) Die Idee der Komponentierung ermöglicht es, die Benutzeroberfläche in wiederverwendbare Teile aufzuteilen, um die Lesbarkeit und Wartbarkeit der Code zu verbessern. 2) Das staatliche Management verwaltet dynamische Daten durch Status und Requisiten und ändert sich auslösen UI -Updates. 3) Aktualisieren Sie die Benutzeroberfläche virtuelle DOM -Optimierungsleistung durch die Berechnung des Mindestbetriebs der DOM -Replik im Speicher.

Frontend -Entwicklung mit Reaktionen: Vorteile und TechnikenFrontend -Entwicklung mit Reaktionen: Vorteile und TechnikenApr 17, 2025 am 12:25 AM

Die Vorteile von React sind seine Flexibilität und Effizienz, die sich in: 1) basierendem Design widerspiegeln, verbessert die Wiederverwendbarkeit des Codes. 2) Virtual DOM -Technologie optimiert die Leistung, insbesondere beim Umgang mit großen Mengen an Datenaktualisierungen. 3) Das reiche Ökosystem bietet eine große Anzahl von Bibliotheken und Tools von Drittanbietern. Wenn Sie verstehen, wie React Beispiele funktioniert und verwendet, können Sie seine Kernkonzepte und Best Practices beherrschen, um eine effiziente, wartbare Benutzeroberfläche zu erstellen.

Reagieren Sie gegen andere Frameworks: Vergleichen und KontrastoptionenReagieren Sie gegen andere Frameworks: Vergleichen und KontrastoptionenApr 17, 2025 am 12:23 AM

React ist eine JavaScript -Bibliothek zum Erstellen von Benutzeroberflächen, die für große und komplexe Anwendungen geeignet sind. 1. Der Kern von React ist Komponentierung und virtuelles DOM, wodurch die UI -Rendering -Leistung verbessert wird. 2. Im Vergleich zu VUE ist React flexibler, hat aber eine steile Lernkurve, die für große Projekte geeignet ist. 3. Im Vergleich zum Angular ist React leichter, hängt von der Gemeinschaftsökologie ab und geeignet für Projekte, die Flexibilität erfordern.

Entmystifizierende Reaktionen in HTML: Wie alles funktioniertEntmystifizierende Reaktionen in HTML: Wie alles funktioniertApr 17, 2025 am 12:21 AM

React arbeitet in HTML über virtuelles DOM. 1) React verwendet die JSX-Syntax, um HTML-ähnliche Strukturen zu schreiben. 2) Virtual DOM -Management -UI -Update, effizientes Rendering durch Differungsalgorithmus. 3) Verwenden Sie Reactdom.render (), um die Komponente zum realen DOM zu rendern. 4) Optimierung und Best Practices umfassen die Verwendung von React.MEMO und Komponentenaufteilung zur Verbesserung der Leistung und Wartbarkeit.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

SublimeText3 Englische Version

SublimeText3 Englische Version

Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)