Heim > Web-Frontend > uni-app > Detaillierte Einführung in das relevante Wissen über Anfragen und Bearbeitungsergebnisse in Uniapp

Detaillierte Einführung in das relevante Wissen über Anfragen und Bearbeitungsergebnisse in Uniapp

PHPz
Freigeben: 2023-04-27 10:32:29
Original
2897 Leute haben es durchsucht

Mit der Entwicklung des mobilen Internets steigt die Marktnachfrage nach mobilen Anwendungen. Als Reaktion auf diese Nachfrage sind verschiedene plattformübergreifende Frameworks wie React Native und Flutter entstanden. Unter anderem ist Uniapp ein Framework, mit dem plattformübergreifende Anwendungen entwickelt werden können. Es kann schnell mehrere Plattformen wie Android, iOS, Web, WeChat-Applets und Alipay-Applets erstellen.

In Uniapp ist das Senden von Anfragen und die Verarbeitung von Anfrageergebnissen eine Kernfunktion. In diesem Artikel werden die relevanten Kenntnisse über Anfragen und Verarbeitungsergebnisse in Uniapp ausführlich vorgestellt.

1. Senden von Anfragen

Es gibt viele Möglichkeiten, Anfragen in Uniapp zu senden. Die häufigste Methode ist die Verwendung der uni.request-Methode.

uni.request({
    url: 'http://www.example.com',
    data: {
        name: 'example'
    },
    header: {
        'content-type': 'application/json'
    },
    success: function (res) {
        console.log(res.data)
    }
});
Nach dem Login kopieren

In diesem Code ist uni.request die Methode zum Senden einer Anfrage. Es muss ein Objekt übergeben werden, das Parameter wie URL, Daten, Header, Erfolg usw. enthält, wobei URL die Anfrageadresse und Daten die Adresse darstellt Die angeforderten Daten und der Header stellen den Anforderungsheader dar. Erfolg stellt die Rückruffunktion dar, nachdem die Anforderung erfolgreich war. Während des Anforderungsprozesses können Sie auch die Parameter „fail“ und „complete“ übergeben, die den Anforderungsfehler bzw. die Rückruffunktion nach Ende der Anforderung darstellen.

Eine andere Möglichkeit, eine Anfrage zu senden, besteht darin, die gekapselte uni.request-Methode zu verwenden und sie in eine separate JS-Datei zu kapseln.

//request.js
import { getBaseUrl } from './config';

const req = (url, method, data) => {
    return new Promise((resolve, reject) => {
        uni.request({
            url: getBaseUrl() + url,
            method,
            data,
            header: {
                'content-type': 'application/json'
            },
            success: (res) => {
                resolve(res)
            },
            fail: (err) => {
                reject(err);
            }
        });
    });
}

export const post = (url, data) => {
    return req(url, 'POST', data);
}

export const get = (url, data) => {
    return req(url, 'GET', data);
}
Nach dem Login kopieren

In diesem Code ist eine req-Methode gekapselt, die die drei Parameter URL, Methode und Daten übergibt und ein Promise-Objekt zurückgibt. Über das Promise-Objekt werden asynchrone Vorgänge implementiert, und die Ergebnisse erfolgreicher und fehlgeschlagener Anforderungen sind an die Auflösungs- und Ablehnungsmethoden übergeben. Gleichzeitig sind auch die Get- und Post-Methoden gekapselt, die das Senden von Get- und Post-Anfragen darstellen. Die Verwendung ist wie folgt:

import { get, post } from './request';

get('/user', {id: 1}).then(res => {
    console.log(res.data);
});

post('/login', {username: 'example', password: 'example'}).then(res => {
    console.log(res.data);
});
Nach dem Login kopieren

2 Verarbeitung der Anforderungsergebnisse

Das Anforderungsergebnis in Uniapp ist im Allgemeinen ein JSON-Objekt, wie unten gezeigt:

{
    "code": 200,
    "message": "success",
    "data": {
        "username": "example",
        "age": 18
    }
}
Nach dem Login kopieren

Dabei stellt Code den Statuscode dar, Nachricht stellt die Nachricht dar und Daten stellen die Anforderungsergebnisdaten dar.

Bei der Verarbeitung des Anforderungsergebnisses müssen Sie zunächst anhand des Codes feststellen, ob die Anforderung erfolgreich ist, und sie anhand verschiedener Statuscodes entsprechend behandeln. Es kann in der Erfolgsrückruffunktion der Anforderungsmethode oder in der gekapselten Methode verarbeitet werden.

import { get } from './request';

get('/user', {id: 1}).then(res => {
    if(res.code === 200) {
        console.log(res.data);
    } else if(res.code === 401) {
        console.log('用户未登录');
    } else if(res.code === 404) {
        console.log('用户不存在');
    } else {
        console.log('请求失败');
    }
});
Nach dem Login kopieren

Eine andere Möglichkeit, Anfrageergebnisse zu verarbeiten, ist die Verwendung von Interceptoren. Ein Interceptor ist eine Funktion, die die Anfrage vor dem Senden der Anfrage oder nach der Antwort auf die Anfrage verarbeiten kann, z. B. das Hinzufügen von Token, das Filtern von Daten usw. Die Art und Weise, Interceptoren in Uniapp zu verwenden, besteht darin, einen Anforderungs-Interceptor und einen Antwort-Interceptor zu kapseln, um die Logik vor und nach der Anforderung zu verarbeiten.

//request.js
import { getBaseUrl } from './config';

const requestInterceptors = (config) => {
    //添加token或其他逻辑
    return config;
}

const responseInterceptors = (response) => {
    const res = response.data;
    if(res.code === 200) {
        return res.data;
    } else {
        //根据code进行错误处理
        uni.showToast({
            title: res.message,
            icon: 'none'
        });
        return Promise.reject(res);
    }
}

const request = (options) => {
    const { url, method = 'GET', data } = options;
    const config = {
        url: getBaseUrl() + url,
        method,
        data,
        header: {
            'content-type': 'application/json'
        }
    }

    return new Promise((resolve, reject) => {
        uni.request({
            ...requestInterceptors(config),
            success: (response) => {
                if(response.statusCode == 200) {
                    resolve(responseInterceptors(response));
                } else {
                    reject(response)
                }
            },
            fail: (error) => {
                reject(error);
            }
        });
    })
}

export default request;

//config.js
export const getBaseUrl = () => {
    //返回请求地址
    return 'http://www.example.com';
}
Nach dem Login kopieren

In diesem Code sind RequestInterceptors, ResponseInterceptors und Request-Methoden gekapselt, und der Request-Interceptor und der Response-Interceptor sind darin gekapselt. Die Funktion von requestInterceptors und ResponseInterceptors besteht darin, die Anfrage vor bzw. nach der Anfrage zu verarbeiten. Die Anforderungsmethode ist eine Methode zum Senden von Anforderungen. Die Verwendungsmethode ist wie folgt:

import request from './request';

request({
    url: '/user',
    method: 'get',
    data: {id: 1}
}).then(res => {
    console.log(res);
}).catch(err => {
    console.log(err);
});
Nach dem Login kopieren

Der endgültige Produktcode ist der optimierte Code:

//config.js
export const getBaseUrl = () => {
    //返回请求地址
    return 'http://www.example.com';
}

//request.js
import { getBaseUrl } from './config';

const requestInterceptors = (config) => {
    //添加token或其他逻辑
    return config;
}

const responseInterceptors = (response) => {
    const res = response.data;
    if(res.code === 200) {
        return res.data;
    } else {
        //根据code进行错误处理
        uni.showToast({
            title: res.message,
            icon: 'none'
        });
        return Promise.reject(res);
    }
}

const request = (options) => {
    const { url, method = 'GET', data } = options;
    const config = {
        url: getBaseUrl() + url,
        method,
        data,
        header: {
            'content-type': 'application/json'
        }
    }

    return new Promise((resolve, reject) => {
        uni.request({
            ...requestInterceptors(config),
            success: (response) => {
                if(response.statusCode == 200) {
                    resolve(responseInterceptors(response));
                } else {
                    reject(response)
                }
            },
            fail: (error) => {
                reject(error);
            }
        });
    })
}

export default request;

//api.js
import request from './request';

export const getUser = (id) => {
    return request({
        url: '/user',
        method: 'get',
        data: {id}
    });
}

//页面中使用
import { getUser } from './api';

getUser(1).then(res => {
    console.log(res);
}).catch(err => {
    console.log(err);
});
Nach dem Login kopieren

Dieser Artikel stellt das relevante Wissen über Anfragen und Verarbeitungsergebnisse in Uniapp vor, einschließlich des Sendens von Anfragen und Verarbeitung von Anfrageergebnissen auf verschiedene Arten sowie Verwendung von Interceptoren für die Vor- und Nachbearbeitung von Anfragen. Für Entwickler, die Uniapp für die plattformübergreifende Anwendungsentwicklung verwenden, wird die Beherrschung dieses Wissens dazu beitragen, die Entwicklungseffizienz und Codequalität zu verbessern sowie die Anwendungsstabilität und Benutzererfahrung zu verbessern.

Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in das relevante Wissen über Anfragen und Bearbeitungsergebnisse in Uniapp. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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