Heim > Web-Frontend > js-Tutorial > So implementieren Sie eine elegante Lösung für Front-End-Ajax-Anfragen

So implementieren Sie eine elegante Lösung für Front-End-Ajax-Anfragen

php中世界最好的语言
Freigeben: 2018-03-30 16:37:21
Original
1765 Leute haben es durchsucht

Dieses Mal zeige ich Ihnen, wie Sie eine elegante Lösung für Front-End-Ajax-Anfragen implementieren. Was sind die Vorsichtsmaßnahmen für die Implementierung einer eleganten Lösung für Front-End-Ajax-Anfragen? Schauen Sie mal rein.

Vorwort

AJAX, Asynchrones JavaScript und XML (asynchrones JavaScript und XML), eine Möglichkeit, interaktives Web zu erstellen Entwicklung von Technologielösungen für Webanwendungen.

Asynchrones JavaScript:

Verwenden Sie [JavaScript-Sprache] und verwandte [vom Browser bereitgestellte Klassenbibliothek]-Funktionen, um eine Anfrage an den Server zu senden, [führen Sie automatisch eine bestimmte aus Eine JavaScript-Callback-Funktion ].

PS: Der gesamte Prozess der obigen Anfrage und Antwort erfolgt [heimlich] ohne jegliche Wahrnehmung auf der Seite.

Im Folgenden gibt es nicht viel zu sagen, werfen wir einen Blick auf den Text dieses Artikels.

Der http-Client dieses Artikels ist axios

Lassen Sie mich zunächst eine Geschichte erzählen

Ähnlich wie axios Die API, die Promise unterstützt, ist bereits sehr benutzerfreundlich. Nachdem die Anfrage erfolgreich war, können wir die vom Backend zurückgegebenen Daten aus der Antwort erhalten. Beispiel:

axios.get('/user/12345')
 .then((response) => {
 console.log(response);
 })
 .catch((error) => {
 console.log(error);
 });
Nach dem Login kopieren

Daten befinden sich in response.data, was bedeutet, dass wir für jede Anfrage einen weiteren Prozess durchführen müssen, um die tatsächlichen Daten zu erhalten.

Dann stellt uns das eigentliche Szenen-Backend die Daten grundsätzlich nicht direkt zur Verfügung. Die Struktur von response.data sieht beispielsweise so aus:

{
 "date": "2017-12-14 15:21:38",
 "success": true,
 "obj": {
 ...
 },
 "version": "V1.0"
}
Nach dem Login kopieren

Also, response.data.obj sind die Daten, die wir wirklich wollen, also müssen wir für jede Anfrage einen weiteren Prozess durchführen =_=

Plötzlich sagte das Backend eines Tages: „response.data ist kein Daten mehr Objekt. Es wurde in JSONString geändert, bitte führen Sie eine Verarbeitung durch~"

Dann müssen wir ja, jede Schnittstelle, jede einzelne, in JSON.parse(response.data).obj, Halbwertszeit, ändern!

Wenn das Backend sagt: „Ich habe das Objekt erneut geändert, können Sie die vorherige Verarbeitung rückgängig machen~“. . .

Wenn das Backend sagt: „Nicht alle sind Objekte, einige sind JSON-Strings. Einzelheiten finden Sie im aktualisierten Schnittstellendokument~“. . .

Wenn wir uns nie getroffen hätten. . .

Später werden wir

ES6-Proxy wird verwendet, um das Standardverhalten bestimmter Vorgänge zu ändern, was einer Änderung auf Sprachebene entspricht. Es gehört also zu einer Art „Meta-Programmierung“, also dem Programmieren in Programmiersprache.

Proxy kann als Einrichtung einer „Abfangschicht“ vor dem Zielobjekt verstanden werden, die zunächst diese Abfangschicht passieren muss, sodass ein Mechanismus zum Abfangen des externen Zugriffs bereitgestellt wird. Filtern und neu schreiben.

Um die oben genannten Probleme zu lindern, müssen wir alle Schnittstellenanforderungen einheitlich kapseln. Selbst wenn sich das Backend immer wieder ändert, müssen wir auf diese Weise nur eine Stelle oder gar keine Änderungen vornehmen!

const apiService = new Proxy(axios, {
 get (target, propKey, receiver) {
 return function (...args) {
 return target[propKey](...args)
 .then((res) => {
  const resData = typeof res.data === 'string' ? JSON.parse(res.data) : res.data;
  return typeof resData.obj === 'string' ? JSON.parse(resData.obj) : resData.obj;
 })
 .catch((err) => {
  throw err;
 });
 }
 }
});
Nach dem Login kopieren

Der entsprechende Schnittstellenanforderungsteil wurde geändert in:

apiService.get('/user/12345')
 .then((data) => {
 console.log(data);
 })
 .catch((error) => {
 console.log(error);
 });
Nach dem Login kopieren

Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen erhalten Sie zu anderen verwandten Artikeln auf der chinesischen PHP-Website!

Empfohlene Lektüre:

Ajax+PHP-Code zum Ändern des Status und Löschen ohne Aktualisierung

So implementieren Sie den Ajax-Client asynchron Aufruf des Servers

Das obige ist der detaillierte Inhalt vonSo implementieren Sie eine elegante Lösung für Front-End-Ajax-Anfragen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage