小程序請求加載提示防閃爍機制詳解

目錄

一、問題背景:閃爍現象的產生

二、完整解決方案代碼

三、核心防閃爍機制解析

1. 請求計數器(requestCount)

2. 延遲隱藏定時器(關鍵創新)

3. 100ms緩沖期的重要意義

四、關鍵場景對比分析

場景1:連續快速請求

五、為什么簡化方案不行?

六、設計思想總結


?

// 典型問題代碼
if (requestStart) {wx.showLoading();
}requestComplete() {wx.hideLoading(); // 快速切換導致閃爍
}

一、問題背景:閃爍現象的產生

在小程序開發中,當多個網絡請求快速連續觸發時,使用wx.showLoading()wx.hideLoading()控制加載提示會出現閃爍問題:

閃爍原因

  1. 請求A完成 → 隱藏Loading

  2. 請求B開始 → 立即顯示Loading

  3. 用戶視覺感知:加載提示快速消失又出現 →?界面閃爍

二、完整解決方案代碼

let requestCount = 0; // 全局請求計數器
let timerId = null;  // 定時器ID// 請求開始時
if (loading) {requestCount++;if (requestCount === 1) {wx.showLoading({ title: "加載中...", mask: true });}
}// 請求完成時complete: function (params) {// 處理loading隱藏if (loading) {requestCount--;// 使用定時器防止loading閃爍 清除上一次的定時器if (timerId) {clearTimeout(timerId);timerId = null;}timerId = setTimeout(() => {if (requestCount <= 0) {requestCount = 0; // 確保不會為負數wx.hideLoading();// 清除定時器{最后一次請求}clearTimeout(timerId);timerId = null;}}, 500); // 500ms延遲,防止快速連續請求造成閃爍}},

?

三、核心防閃爍機制解析

1. 請求計數器(requestCount)
// 請求開始
requestCount++; // 增加計數// 請求完成
requestCount--; // 減少計數
  • 作用:合并多個請求狀態

  • 原理

    • requestCount > 0時保持Loading顯示

    • 只有歸零時才允許隱藏

  • 優勢:避免單請求完成就隱藏的問題

2. 延遲隱藏定時器(關鍵創新)
if (timerId) clearTimeout(timerId); // 取消前次待執行操作timerId = setTimeout(() => {// 最終檢查
}, 100);
  • 雙重保護機制

    1. clearTimeout:中斷前序未執行的隱藏操作

    2. setTimeout:延遲100ms執行最終狀態檢查

3. 100ms緩沖期的重要意義
時間點無定時器方案有定時器方案
請求B完成立即隱藏Loading計劃100ms后隱藏
請求C開始(50ms)立即顯示 → 閃爍清除隱藏計劃 → 保持顯示
最終效果閃爍持續平穩顯示

四、關鍵場景對比分析

場景1:連續快速請求

場景2:網絡波動請求?

五、為什么簡化方案不行?

問題代碼

complete: function() {if (loading) {requestCount--;if (requestCount <= 0) {wx.hideLoading(); // 立即隱藏}}
}

?

致命缺陷

  1. 在快速連續請求場景下:

    • 請求B完成 → 立即隱藏

    • 請求C開始 → 立即顯示

    • 間隔可能小于50ms → 人眼可感知閃爍

  2. 網絡波動時:

    • 請求失敗重試 → 顯示/隱藏頻繁切換

    • 用戶體驗割裂

六、設計思想總結

  1. 狀態聚合:通過計數器合并請求狀態

  2. 延遲響應:100ms緩沖期觀察后續請求

  3. 操作可中斷clearTimeout保證只響應最終狀態

  4. 臨界值保護requestCount = 0防止負數

防抖思想應用:這種模式本質是前端防抖(debounce)技術的變種,將高頻的狀態變更合并為單次穩定操作。100ms延遲經過實踐驗證,在用戶體驗和響應速度間達到最佳平衡。

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

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

相關文章

linux防火墻講解

目錄 安全管理 一、SELinux安全上下文 1、SELinux 簡介 2、基礎操作命令 1. 查看SELinux狀態 2. 切換工作模式* 3、安全上下文&#xff08;Security Context&#xff09; 1. 查看上下文* 2. 修改上下文 chcon命令 semanage 命令 4、SELinux布爾值&#xff08;Boole…

巧用 Python:將 A3 作業 PDF 輕松轉為 A4 可打印格式

在孩子的學習過程中&#xff0c;我們常常會遇到這樣的困擾&#xff1a;學校老師發的作業是以 A3 格式的 PDF 文件呈現的&#xff0c;然而家里的打印機卻只支持 A4 打印。這時候&#xff0c;要是能有一個簡單的方法把 A3 的 PDF 轉換為 A4 可打印的格式就好了。別擔心&#xff0…

Transformer 核心概念轉化為夏日生活類比

以下是把 Transformer 核心概念轉化為「夏日生活類比」&#xff0c;不用看代碼也能秒懂&#xff0c;搭配冰鎮西瓜式記憶法&#xff1a; 一、Transformer 夏日冷飲制作流水線 編碼器&#xff08;Encoder&#xff09;&#xff1a;相當于「食材處理間」 把輸入&#xff08;比如…

【Linux基礎知識系列】第二十九篇-基本的網絡命令(ping, traceroute, netstat)

在Linux系統中&#xff0c;網絡診斷是系統管理員和用戶日常工作中不可或缺的一部分。無論是排查網絡連接問題、檢查網絡延遲&#xff0c;還是監控網絡狀態&#xff0c;掌握一些基本的網絡命令至關重要。本文將詳細介紹ping、traceroute和netstat這三種常用的網絡命令&#xff0…

javaee初階-多線程

1.什么是線程 1.1 進程 要了解線程我們首先需要了解什么是進程&#xff1f; 運行的程序在操作系統中以進程的方式運行&#xff0c;比如說電腦打開不同的軟件&#xff0c;軟件就是不同的進程 1.1.1進程的組織方式 通過雙向鏈表 創建進程就是在雙向鏈表上添加PCB 銷毀一個進…

N數據分析pandas基礎.py

前言&#xff1a;在數據分析領域&#xff0c;Python 的 Pandas 庫堪稱得力助手。它不僅擁有高效的數據處理能力&#xff0c;還能與 NumPy 完美配合——后者強大的數值計算功能為 Pandas 提供了堅實的技術基礎。 目錄 Pandas數據分析實戰&#xff1a;解鎖數據處理的高效之道 數…

衛星通信鏈路預算之二:帶寬和功帶平衡

在上一個章節衛星通信鏈路預算之一&#xff1a;信噪比分配 中&#xff0c;我們介紹了衛星通信鏈路中最核心的概念&#xff1a;信噪比分配&#xff0c;并給出了衛星通信鏈路總信噪比的計算公式。 本篇文章&#xff0c;我們將介紹衛星通信鏈路中的另外一個基本概念&#xff1a;帶…

QGIS新手教程5:圖層屬性查詢與表達式篩選技巧

? QGIS新手教程5&#xff1a;圖層屬性查詢與表達式篩選技巧 字段篩選、表達式構建器、選擇集操作一步到位&#xff01; 目錄 ? QGIS新手教程5&#xff1a;圖層屬性查詢與表達式篩選技巧&#x1f4c1; 一、示例數據準備&#xff08;繼續使用第四篇中的示例&#xff09;&#…

用 el-dialog 做出彈出框是圖片

今天項目上用到個功能是點擊按鈕彈出一個 modal&#xff0c;有遮罩層而且在上面顯示圖片。 其實就是 el-dialog 的功能&#xff0c;但是 el-dialog 彈出后&#xff0c;有標簽關閉按鈕還有背景。 解決辦法&#xff1a;el-dialog 的 width 設為 0 就可以了。 <template>…

Gartner《Decision Point for Selecting the Right APIMediation Technology》學習心得

一、API 中介技術概述 背景&#xff0c;API 中介技術變得多樣化&#xff0c;應用與集成架構師需要借助決策框架&#xff0c;從企業級 API 網關、輕量級網關、入口網關以及服務網格中挑選出適合多粒度服務和 API 的中介技術。 隨著無服務器架構與容器管理系統的興起&#xff0…

快速 SystemC 之旅(一)

快速 SystemC 之旅&#xff08;一&#xff09; 一、前言背景二、實驗環境1. 安裝步驟2. 驗證安裝 三、RTL 級硬件描述1. 初看模塊2. 二輸入與非門 一、前言背景 因項目需求&#xff0c;近期開始開展電子系統級設計&#xff08;ESL&#xff09;進行事務級建模&#xff08;TLM&a…

解決 Golang 下載golang.org/x包失敗方案

在 Golang 開發過程中&#xff0c;不少開發者都遇到過這樣的困擾&#xff1a;當試圖下載golang.org相關包時&#xff0c;會出現訪問失敗的情況&#xff0c;尤其是golang.org/x系列包&#xff0c;作為眾多第三方庫依賴的核心組件&#xff0c;其無法正常下載會嚴重影響項目的開發…

CppCon 2016 學習:BUILDING A MODERN C++ FORGE FOR COMPUTE AND GRAPHICS

你提供的這段文字是關于 設計一個精簡但足夠的 C 框架來驅動 Vulkan 的目標陳述&#xff0c;屬于項目文檔或演講的第一部分 “Goals”。我們可以把它逐項拆解并深入理解&#xff1a; PART (I – I): GOALS&#xff08;目標&#xff09; 總體目標&#xff1a; 構建一個最小但足…

# AI武裝大腦:技術管理者如何用人工智能重構認知與決策系統

作為一位經歷了15年技術管理實戰的老兵&#xff0c;我見過太多項目因為決策失誤、認知局限而陷入泥潭。直到我開始系統性地用AI武裝大腦&#xff0c;才真正找到了突破技術管理瓶頸的利器。今天&#xff0c;我要分享的不是那些泛泛而談的AI概念&#xff0c;而是如何用AI真正提升…

【Linux】UDP與TCP協議

目錄 UDP協議 1.1通信流程 1.2函數 socket bind sendto recvfrom close 1.3實現udp通信 TCP協議 1.1TCP頭部結構 1.2通信流程 三次握手 正式通信 四次揮手 1.3協議特性 面向字節流 可靠傳輸 序列號和確認號 重傳機制 流量控制和擁塞控制 1.4常用函數 s…

gbase8s之MyBatis批量update問題

源代碼 <update id"updateDynamicTableData"><foreach collection"mapList" item"map" separator";">UPDATE ${tableName} SET<foreach collection"map" item"value" index"key" separ…

博圖SCL中WHILE語句的使用詳解及案例

在西門子TIA Portal的SCL&#xff08;結構化控制語言&#xff09;編程中&#xff0c;WHILE循環是處理條件迭代任務的核心工具。它根據布爾表達式動態控制循環執行&#xff0c;適用于不確定循環次數的場景。下面從語法、執行流程、注意事項到實際案例全面解析。 一、WHILE循環基…

簡單聊聊JVM中的幾種垃圾收集算法

3.4、分代收集算法 分代收集算法&#xff0c;可以看成以上內容的延伸。它的實現思路是根據對象的生命周期的不同&#xff0c;將內存劃分為幾塊&#xff0c;比如把堆空間劃分為新生代和老年代&#xff0c;然后根據各塊的特點采用最適當的收集算法。 在新生代中&#xff0c;存在…

依賴已導入,已下載,無法使用問題

明明已經導入依賴&#xff0c;卻無法使用相關注解 于是&#xff0c;我使用 mvn dependency:tree -Dverbose 來查看是否有依賴沖突 [INFO] ------------------------------------------------------------------------ [ERROR] Failed to execute goal on project agileboot…

答題考試系統小程序ThinkPHP+UniApp

ThinkPHPUniapp開發的小程序答題考試系統&#xff0c;支持多種試題類型、多種試題難度、練題、考試、補考模式&#xff0c;提供全部前后臺無加密源代碼&#xff0c;支持私有化部署. 更新日志 V1.7.1修復一些問題 解決考場成績列表重復問題&#xff1b; 解決后臺材料題選擇子…