モバイル インターネット時代の到来により、APP は人々の生活に欠かせないものになりました。より良いサービスとユーザー エクスペリエンスを提供するために、APP でのネットワーク リクエストの使用は不可欠なリンクとなっています。ネットワーク要求を効果的にカプセル化し、コードの再利用性と保守性を向上させる方法が重要なトピックとなっています。この記事では、uniapp プロジェクトでネットワーク リクエスト メソッドをカプセル化する方法を紹介します。
1. uniapp のネットワーク リクエスト
uniapp フレームワークは Vue.js フレームワークに基づいて開発されているため、uniapp のネットワーク リクエスト メソッドは Vue.js と似ています。 uniapp でネットワーク リクエストを使用するには、uni.request メソッドを使用する必要があります。構文は次のとおりです:
uni.request({ url: '', data: {}, header: {}, method: 'GET', dataType: 'json', responseType: 'text', success: res => {}, fail: () => {}, complete: () => {} })
パラメータの意味は次のとおりです:
: インターフェイス アドレス
: キーと値のペアで渡されるリクエスト パラメーター
: 渡されるリクエスト ヘッダー パラメーターキーと値のペア
: リクエスト メソッド。GET、POST、PUT、DELETE などをサポートします。
: データ型。デフォルトは json
: 応答データ型、デフォルトは text
: 成功のコールバック関数
: 失敗コールバック関数
: リクエスト完了コールバック関数
function request(url, data, method = 'GET', header = {}) { return new Promise((resolve, reject) => { uni.request({ url, data, method, header, success: res => { resolve(res.data) }, fail: err => { reject(err) } }) }) }
Promise オブジェクトを使用して、
uni.request メソッドをカプセル化して返します。 Promise オブジェクト。これにより、リクエストが成功または失敗したときに対応する処理を実行できます。
import Config from '@/config' function request(url, data = {}, method = 'GET', header = {}) { return new Promise((resolve, reject) => { uni.request({ url: Config.baseUrl + url, data, method, dataType: 'json', header: { 'Content-Type': 'application/json', ...header }, success: res => { resolve(res.data) }, fail: err => { reject(err) } }) }) } export default { install(Vue, options) { Vue.prototype.$http = { get: (url, data, header) => { return request(url, data, 'GET', header) }, post: (url, data, header) => { return request(url, data, 'POST', header) }, put: (url, data, header) => { return request(url, data, 'PUT', header) }, delete: (url, data, header) => { return request(url, data, 'DELETE', header) } } } }
Config を導入します。また、インターフェイス プレフィックス、データ型などの一般的なリクエスト パラメーターも構成しました。最後に、共通パラメータと
Promise を実装するネットワーク リクエスト メソッドが、
Vue.prototype.$http を通じて Vue.js インスタンスにマウントされます。
<template> <view> <button @tap="getData">获取数据</button> <view>{{ message }}</view> </view> </template> <script> export default { data() { return { message: '' } }, methods: { async getData() { try { const res = await this.$http.get('/api/data') console.log(res) this.message = res.message } catch (e) { console.error(e) } } } } </script>
async/await を使用してネットワーク要求を非同期的に処理し、コードの記述を簡素化します。同時に、各コンポーネントでネットワーク リクエストに関連するコードを記述せず、コードの再利用を実現するために Vue.js インスタンスにマウントされた
$http リクエスト メソッドを直接呼び出していることもわかります。
以上がuniapp プロジェクトでネットワーク リクエスト メソッドをカプセル化する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。