UniApp Vue 3 中的網絡請求封裝詳解及用法

在UniApp中,結合Vue 3的強大特性,進行網絡請求的封裝是項目中常見的需求。這樣的封裝不僅提高了代碼的可維護性,還使得在組件中使用網絡請求更加簡潔。本文將詳細介紹UniApp Vue 3中的網絡請求封裝,并提供一個簡單的用法示例。

1. 網絡請求封裝

首先,我們創建一個網絡請求的封裝模塊,通常包括以下幾個部分:

1.1 基礎配置

// request.jslet baseUrl = "";
const env = "dev";if (env === "dev") {baseUrl = 'http://192.168.0.108:8001';
} else if (env === "pro") {baseUrl = 'http://192.168.0.108:8001';
}

上述代碼設置了請求的基礎URL,根據不同的環境(開發或生產)設置不同的地址。

1.2 請求方法封裝

// request.jsconst request = (url, method = 'GET', data = {}, header = {}) => {return new Promise((resolve, reject) => {header["Authorization"] = uni.getStorageSync("token");uni.request({url: baseUrl + url,method: method,data: data,header: header,success: (res) => {if (res.data.code == 401) {uni.reLaunch({url: "/pages/login/login"})}resolve(res.data)},fail: (err) => {let result = { code: 500, msg: "獲取數據失敗" };reject(result)}})})
}

這里定義了一個通用的請求方法 request,接受URL、請求方法、請求數據和請求頭等參數,返回一個Promise對象。在請求成功時,會判斷返回的狀態碼,如果是401,則重新跳轉到登錄頁;否則,將返回的數據通過resolve傳遞出去。請求失敗時,通過reject返回一個包含錯誤信息的對象。

1.3 不同請求方式的封裝

// request.jsconst form = (url, param) => {return request(url, "post", param, { 'Content-Type': 'application/x-www-form-urlencoded' })
}const post = (url, param) => {return request(url, "post", param, { 'Content-Type': 'application/json' })
}

1.4 數據加載方法封裝

// request.jsconst loadPostData = (url, param, ref) => {let res = post(url, param);res.then((res) => {if (res.code !== 200) {return;}ref.value = res.data || [];}).catch((err) => {console.log(err);})
}const loadFormData = (url, param, ref) => {let res = form(url, param);res.then((res) => {if (res.code !== 200) {return;}ref.value = res.data || [];}).catch((err) => {console.log(err);})
}

這兩個方法封裝了不同場景下的數據加載,根據請求方式調用相應的post或form方法,然后根據返回的數據進行相應的處理。

1.5 回調方式封裝

// request.jsconst loadPostCallback = (url, param, callback) => {let res = post(url, param);res.then((res) => {if (res.code !== 200) {return;}let data = res.data || [];if (callback) {callback(data);}}).catch((err) => {console.log(err);})
}

這個方法在數據加載成功后執行回調函數,適用于需要在數據加載完成后執行額外操作的場景。

1.6 導出模塊

// request.jsexport default { request, form, post, loadPostData, loadFormData, loadPostCallback };

最后,通過export default導出整個模塊,以便在其他文件中引用。

2. 使用封裝后的網絡請求

有了以上的封裝,我們可以在Vue組件中使用如下:

// YourComponent.vue<template><!-- Your component template -->
</template><script>
import { ref } from 'vue';
import request from '@/path-to-request-module'; // 替換為實際的路徑export default {setup() {const data = ref([])const fetchData = () => {let param = {appKey: "miniPage",fetch: "1",depth: "1"}request.loadPostData("/appMenu/list", param, data)}// 在適當的生命周期或事件中調用 fetchData// 例如:onMounted(fetchData) 或者 在某個按鈕點擊事件中調用return {data,fetchData}}
}
</script>

上述代碼中,我們引入了ref用于創建響應式變量,然后導入了我們封裝好的網絡請求模塊。在setup函數中,我們定義了一個名為data的響應式變量和一個名為fetchData的函數,用于發起網絡請求。

在fetchData函數中,我們定義了請求參數 param,然后調用request.loadPostData方法進行數據加載。這樣,我們在組件中只需關注數據的使用和業務邏輯,網絡請求的具體實現被封裝在了request模塊中。

這樣的封裝使得代碼更加清晰,降低了組件的復雜度,同時也提高了代碼的可維護性。

通過這種方式,你可以輕松地在Vue 3中進行網絡請求,并在項目中重用封裝好的請求方法。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/710690.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/710690.shtml
英文地址,請注明出處:http://en.pswp.cn/news/710690.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

索引使用規則4——覆蓋索引回表查詢

覆蓋索引&#xff1a;查詢使用了索引&#xff0c;并且需要返回的列&#xff0c;在索引里面都可以找到&#xff0c;減少select*的使用 1、using index condition Extra 為using index condition 表明查找使用了索引&#xff0c;但是需要回表查詢&#xff08;也就是先二級索引&…

第十八屆全國大學生智能汽車競賽——攝像頭算法(附帶個人經驗)

文章目錄 前言一、攝像頭圖像處理1、攝像頭圖像采集2、圖像二值化與大津算法 二、左右邊界&#xff0c;中線掃描 前言 參加了第十六&#xff0c;十七和第十八屆全國大學生智能車競賽&#xff0c;對攝像頭的學習有部分心得&#xff0c;分享給大家&#xff0c;三屆車賽&#xff…

【C語言基礎】:深入理解指針(一)

文章目錄 一、內存和地址1. 內存2. 如何理解編址 二、指針變量和地址2.1 取地址操作符(&)2.2 指針變量和解引用操作符(*)2.2.1 指針變量2.2.2 如何拆解指針變量2.2.3 解引用操作符 2.3 指針變量的大小 三、指針變量類型的意義3.1 指針的解引用3.2 指針 - 整數3.3 void*指針…

HCIA-HarmonyOS設備開發認證V2.0-習題

目錄 習題一習題二&#xff08;待續...&#xff09;堅持就有收獲 習題一 # HarmonyOS簡介 1. 以下哪幾項屬于OpenHarmony的技術特性&#xff1f;&#xff08;&#xff09;A. 統一OS&#xff0c;彈性部署B. 一次開發&#xff0c;多端部署C. 硬件互助&#xff0c;資源共享2. Ope…

從零開始的Java知識(下)

從零開始的Java知識 雙列數據集合&#xff08;Day1&#xff09;Map 雙列數據集合&#xff08;Day1&#xff09; Map 注意點&#xff1a; Map一次加入一個key-value一個key對應一個valuekey與key之間是不重復的key-value被稱為鍵值對&#xff0c;鍵值對對象或者是entry對象 …

離散數學

(理解大于識記, 這么多公式我是記不住) 命題邏輯 P P P Q Q Q P \neg P P 否定/非 P ∧ Q P \wedge Q P∧Q 合取/與 P ∨ Q P \vee Q P∨Q 析取/或 P → Q P \to Q P→Q 蘊含 P ? Q P \leftrightarrow Q P?Q 等價0010011011011010001001101111 P → Q P\to Q P→Q 的自然語…

openssl 加密文件(支持大文件,對稱、非對稱)

一、非對稱加密&#xff08;小文件&#xff09; 生成 2048 位密鑰 openssl genrsa -out rsa2048.key 2048從 rsa2048.key 密鑰文件中提取出公鑰 pub2048.key openssl rsa -in rsa2048.key -pubout -out pub2048.key使用 pub2048.key 公鑰加密一個文件 (data.zip 為原始文件&…

C# WPF編程-創建項目

1.創建新項目 選擇“WPF應用程序”》“下一步” 2. 設置項目 設置項目名稱&#xff0c;保存位置等參數>下一步 3.選擇框架 4.項目創建成功 5.運行項目

兩張二值化圖像融合

python實現&#xff0c;已知兩張二值化圖像&#xff0c;對比兩張圖&#xff0c;將像素點一致的坐標保留原來顏色&#xff0c;不一致的坐標像素值變為128 讀取原圖 import cv2 import matplotlib.pyplot as plt import numpy as npcup_file_pathname"/home/wzc/zlt_self/…

vue-顯示數據

? v-text和v-html專門用來展示數據, 其作用和插值表達式類似。v-text和v-html可以避免插值閃爍問題. ? 當網速比較慢時, 使用{{}}來展示數據, 有可能會產生插值閃爍問題。 ? 插值閃爍: 在數據未加載完成時&#xff0c;頁面會顯示出原始的{{}}, 過一會才會展示正常數據.語法…

Opencv實戰(5)平滑處理與常見函數

平滑處理 Opencv實戰&#xff1a; Opencv(1)讀取與圖像操作 Opencv(2)繪圖與圖像操作 Opencv(3)詳解霍夫變換 Opencv(4)詳解輪廓 文章目錄 平滑處理1.均值濾波2.方框濾波3.高斯濾波4.中值濾波5.雙邊濾波 常見函數(1).createTrackbar()(2).SetMouseCallback() 圖像的平滑處理是…

細數Android開發者的艱辛歷程,android零基礎

首先我們來看一下組件化項目和傳統項目的區別: 在傳統的項目里 我們通常情況下會有一個commonLib的Libary模塊和一個app的application模塊&#xff0c;業務中的邏輯都寫在app中各個功能模塊放到不同的包下。這樣做有以下幾個主要的缺點&#xff1a; 1.無論分包做的再好&…

【Linux】USB Functionfs編程:libusb接口詳解

1、USB host_app代碼注釋 #include <libusb.h> libusb頭文件,編譯時鏈接庫:libusb-1.0#define VENDOR 0x1d6b 廠商:Linux Foundation #define PRODUCT 0x0105 設備:FunctionFS Gadge

Zynq—AD9238數據采集DDR3緩存千兆以太網發送實驗(一)

ACM9238 高速雙通道ADC模塊自助服務手冊AD9238 一、實驗目的 本次實驗通過電腦上的網絡調試助手&#xff0c;將命令幀進行發送&#xff0c;然后通過ACZ7015開發板上的以太網芯片接收&#xff0c;隨后將接收到的數據轉換成命令&#xff0c;從而實現對ACM9238模塊采樣頻率、數據…

JavaScript中的new Proxy()和Object.defineProperty使用詳細,Vue2和vue3中雙向數據綁定的原理

簡介&#xff1a; Object.defineProperty() 是 JavaScript 中一個強大且常用的方法&#xff0c;用于定義對象屬性&#xff0c;允許我們精確地控制屬性的行為&#xff0c;包括讀取、寫入和刪除等操作&#xff0c;是vue2中雙向數據綁定的原理&#xff1b; new Proxy() 是ES6中一…

Tomcat布署及優化

1.Tomcat簡介 Tomcat 是 Java 語言開發的&#xff0c;Tomcat 服務器是一個免費的開放源代碼的 Web 應用服務器&#xff0c;Tomcat 屬于輕量級應用服務器&#xff0c;在中小型系統和并發訪問用戶不是很多的場合下被普遍使用&#xff0c;是開發和調試 JSP 程序的首選。一般來說&…

在實訓云平臺上配置云主機

文章目錄 零、學習目標一、實訓云升級二、實訓云登錄&#xff08;一&#xff09;登錄實訓云&#xff08;二&#xff09;切換界面語言&#xff08;三&#xff09;規劃云主機實例 三、創建網絡三、創建路由器2024-2-29更新到此四、添加接口五、創建端口六、添加安全組規則七、創建…

反相輸入放大器與生俱來的坑

我們都知道反相放大器能將輸入的信號反相放大&#xff0c;這是很基本的知識&#xff0c;學過電路的一般都知道。反相放大器的公式為Vout -Vin*Rf/Rin&#xff08;運算放大器應用匯總&#xff09;。根據已知的公式&#xff0c;能很輕松的完成設計&#xff0c;但反相放大器與生俱…

每日一類:QString類深入講解

QString類是Qt框架中的一個核心組件&#xff0c;設計用于方便、高效地處理Unicode字符串。與標準C中的字符串處理方式相比&#xff0c;QString提供了更為豐富的API&#xff0c;支持國際化&#xff0c;并且內部使用UTF-16編碼&#xff0c;能夠處理世界上幾乎所有的語言文字。 設…

【PHP進階】Rabbitmq的實際使用

RabbitMQ是一個流行的消息隊列中間件&#xff0c;它提供了可靠的消息傳遞機制。在使用RabbitMQ時&#xff0c;有幾個重要的概念需要了解&#xff1a; 消息隊列&#xff08;Message Queue&#xff09;&#xff1a;RabbitMQ中的核心概念之一。它是消息的緩沖區&#xff0c;用于存…