項目學習筆記 display從none切換成block

跟著視頻學做項目的時候,碰到一個多級聯動列表,列表元素的display會從none切換成block,切換過程中可能導致資源渲染過多,從而導致卡頓問題。

<div class="all-sort-list2"><div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId"@mouseenter="setChooseIndex(index)"><h3 :class="{ chooseNow: nowIndex == index }"><a>{{ list_data1.categoryName }}</a></h3><div class="item-list clearfix" :style="{ display: nowIndex == index ? 'block' : 'none' }"><div class="subitem"><dl class="fore" v-for="list_data2 in list_data1.categoryChild" :key="list_data2.categoryId"><dt><a>{{ list_data2.categoryName }}</a></dt><dd><em v-for="list_data3 in list_data2.categoryChild" :key="list_data3.categoryId"><a>{{ list_data3.categoryName }}</a></em></dd></dl></div></div></div>
</div>

對于這個列表,其內部元素是從服務區獲取數據,然后通過v-for顯示。

類item-list的disblock會不斷從none切換為block。

組件渲染導致使用卡頓

<div class="all-sort-list2"><div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId"@mouseenter="setChooseIndex(index)"><h3 :class="{ chooseNow: nowIndex == index }"><router-link>{{ list_data1.categoryName }}</router-link></h3><div class="item-list clearfix" :style="{ display: nowIndex == index ? 'block' : 'none' }"><div class="subitem"><dl class="fore" v-for="list_data2 in list_data1.categoryChild" :key="list_data2.categoryId"><dt><router-link>{{ list_data2.categoryName }}</router-link></dt><dd><em v-for="list_data3 in list_data2.categoryChild" :key="list_data3.categoryId"><router-link>{{ list_data3.categoryName }}</router-link></em></dd></dl></div></div></div>
</div>

當v-for循環中使用router-link標簽時,隨著display從none切換為block,多個router-link標簽會被重新渲染。由于router-link標簽是VUE組件,當數據過多時,可能一次display切換,會導致上千個VUE組件被重新渲染,因此會造成性能問題。

一個解決辦法是可以把router-link換成a標簽,再在a標簽上綁定click事件處理。

回調函數被多次渲染

<div class="all-sort-list2"><div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId"@mouseenter="setChooseIndex(index)"><h3 :class="{ chooseNow: nowIndex == index }"><a @click="">{{ list_data1.categoryName }}</a></h3><div class="item-list clearfix" :style="{ display: nowIndex == index ? 'block' : 'none' }"><div class="subitem"><dl class="fore" v-for="list_data2 in list_data1.categoryChild" :key="list_data2.categoryId"><dt><a @click="">{{ list_data2.categoryName }}</a></dt><dd><em v-for="list_data3 in list_data2.categoryChild" :key="list_data3.categoryId"><a @click="">{{ list_data3.categoryName }}</a></em></dd></dl></div></div></div>
</div>

但是這種方法仍然存在問題,由于每個a標簽中都綁定了click事件,該事件會被渲染上千次,可以通過事件委托到父級,把事件的渲染降低為一次。

(但這里其實我也不太懂,我覺得雖然事件生成了多個,但是其實不click就不會被調用,不調用也會影響性能嗎)

解決辦法是使用事件委托。

把事件綁定在父級上,然后通過event.target獲得點擊的標簽,進行處理。

<div class="all-sort-list2" @click="goSearch"><div class="item" v-for="(list_data1, index) in list" :key="list_data1.categoryId" ... </div>
</div><script>...goSearch(event){let e = event.target;getAttribute('...');}
</script>

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

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

相關文章

從 “洗澡難” 到 “洗得爽”:便攜智能洗浴機如何重塑生活?

洗澡本應是日常生活的簡單需求&#xff0c;但對于失能老人、行動不便者而言&#xff0c;卻可能成為一項充滿挑戰甚至危險的“艱巨任務”。中國失能、半失能老年人口超過4200萬&#xff0c;傳統助浴方式存在搬運風險高、隱私難以保障、效率低下等問題&#xff0c;使得“洗澡難”…

鷓鴣云重構光伏發電量預測的精度標準

在當今全球能源轉型的大背景下&#xff0c;光伏發電作為一種清潔、可再生的能源形式&#xff0c;正受到越來越多的關注與應用。然而&#xff0c;光伏發電量的精準預測&#xff0c;一直是行業內亟待攻克的關鍵難題。尤其是在面對復雜多變的氣象條件、不同區域的地理環境以及設備…

每日一題(沉淀中)

文章目錄 1、 實現string類的接口&#xff0c;并完成測試&#xff0c;要求利用深拷貝和深賦值實現 MyString.h #pragma once #include<iostream> class MyString { private:char* data;//儲存字符串內容 public://默認構造函數MyString(const char* str nullptr);////拷…

深入淺出Kafka Producer源碼解析:架構設計與編碼藝術

一、Kafka Producer全景架構 1.1 核心組件交互圖 #mermaid-svg-L9jc09hRQCHb0ftl {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-L9jc09hRQCHb0ftl .error-icon{fill:#552222;}#mermaid-svg-L9jc09hRQCHb0ftl .erro…

微軟AutoGen:多智能體協作的工業級解決方案

微軟AutoGen&#xff1a;多智能體協作的工業級解決方案 &#x1f31f; 嗨&#xff0c;我是IRpickstars&#xff01; &#x1f30c; 總有一行代碼&#xff0c;能點亮萬千星辰。 &#x1f50d; 在技術的宇宙中&#xff0c;我愿做永不停歇的探索者。 ? 用代碼丈量世界&#xf…

終端安全管理系統為什么需要使用,企業需要的桌面管理軟件

在當今數字化高度發展的時代&#xff0c;企業和組織的運營計算機等&#xff0c;是企業業務流程的重要節點。終端安全管理系統正揮著至關重要的作用。保障數據安全終端設備往往存儲著企業的核心數據&#xff0c;終端安全管理系統可以保障安&#xff0c;未經授權的人員也無法獲取…

補環境基礎(一) 原型與原型鏈

1.創建對象的幾種方式 1.對象字面量模式 直接使用{}定義鍵值對&#xff1a; const obj { key: value }; 2.Object()構造函數模式 使用內置構造函數&#xff08;較少使用&#xff09;&#xff1a; const person new Object(); console.log(person)//輸出 {}3.構造函數模…

Qt+yolov8目標識別

這是一個基于ONNX Runtime的YOLOv8目標檢測項目&#xff0c;支持CPU和GPU加速&#xff0c;使用Qt框架構建圖形化界面。攝像頭實時畫面識別視頻文件識別&#xff0c;能正常識別目標&#xff1a;紅綠燈&#xff0c;人&#xff0c;公交&#xff0c;巴士&#xff0c;摩托車 等YOLOv…

NLP分詞notes

BPE 貪心提取所有出現頻率高的成為詞。 BPE的訓練流程 1.初始化&#xff1a;將所有單個字符作為初始詞匯表的元素。 2.迭代合并&#xff1a; 統計語料中所有相鄰符號對&#xff08;包括字符和合并后的符號&#xff09;的出現頻率。找到出現頻率最高的符號對&#xff0c;將其合并…

【數據結構】棧和隊列-----數據結構中的雙生花

文章目錄[toc]棧與隊列&#xff1a;數據結構中的雙生花1. 棧&#xff1a;后進先出的有序世界1.1 概念及結構剖析1.2 實現方式深度解析數組 vs 鏈表實現1.3 動態棧實現詳解&#xff08;附程序源碼&#xff09;1.定義一個動態棧2.初始化3.銷毀4.入棧5.出棧6.取棧頂數據7.判空8.獲…

Mybatis-2快速入門

學習主線 必學必會屬于優化的東西。 快速入門需求說明 要求&#xff1a;開發一個MyBatis項目&#xff0c;通過MyBatis的方式可以完成對monster表的crud操作 1.創建mybatis數據庫-monster表 主鍵Primary Key默認非空Not null&#xff0c;就省略了 create database mybatis us…

Web基礎 -java操作數據庫

一、JDBCJDBC&#xff1a;&#xff08;Java DataBase Connectivity&#xff09;&#xff0c;就是使用Java語言操作關系型數據庫的一套API。為了使用JDBC操作數據庫&#xff0c;首先&#xff0c;我們需要在pom.xml文件中引入依賴<dependencies><!-- MySQL JDBC driver …

cell2location復現

https://github.com/BayraktarLab/cell2location/issues/348 根據你已下載的本地 wheel 文件&#xff0c;可以通過以下方式修改安裝命令&#xff0c;優先從本地路徑安裝 jaxlib&#xff0c;同時保持其他依賴的安裝方式不變&#xff1a; 解決方案 # 安裝 jax (從遠程 PyPI 源) p…

什么是 npm、Yarn、pnpm? 有什么區別? 分別適應什么場景?

什么是 npm、Yarn、pnpm? 有什么區別? 分別適應什么場景? 在前端開發中&#xff0c;包管理工具扮演著非常重要的角色。它們幫助開發者高效地管理項目的依賴&#xff0c;確保項目中所需的所有第三方庫和工具都能按時安裝&#xff0c;并且兼容版本。npm、Yarn 和 pnpm 是三款…

深度隱匿源IP:高防+群聯AI云防護防繞過實戰

隱蔽性挑戰 黑客常通過以下手段繞過基礎防護&#xff1a; HTTPS證書嗅探&#xff1a;訪問 https://源站IP&#xff0c;通過證書域名匹配暴露真實IP歷史解析記錄追蹤&#xff1a;從DNS數據庫獲取舊A記錄CDN緩存滲透&#xff1a;利用邊緣節點回源漏洞定位源站 三重防護方案 高防I…

如何加快golang編譯速度

跟著我的步驟來&#xff1a;第一步&#xff1a;(點擊edit)第二步&#xff1a;將go tool arguments設置為-p4&#xff0c;初始值設為4&#xff0c; 代表最多同時編譯4個包&#xff08;非文件&#xff09;。電腦性能好時&#xff0c;可設為CPU最大核心數&#xff08;充分利用多核…

瀏覽器自動化方案

B端后臺列表頁自動新增素材方案 我設計了一套完整的瀏覽器自動化方案&#xff0c;使用 Puppeteer 實現B端后臺列表頁的自動新增素材功能。該方案包含數據組織、瀏覽器操作、錯誤處理等完整流程。 一、技術選型 瀏覽器自動化工具&#xff1a;Puppeteer (https://pptr.dev)任務調…

MPPT電路設計

反激的具體計算過程要寫好起碼要一天&#xff0c;所以本次先更MPPT。這章不計算具體參數&#xff0c;只做分析。 目錄 一、電路作用 二、電路設計 采樣電路和輸入電路 主體電路 驅動電路 一、電路作用 MPPT電路是一種廣泛應用于光伏發電、風力發電等新能源系統中的關鍵電…

【基于飛漿訓練車牌識別模型】

基于飛漿訓練車牌識別模型 基于飛漿訓練車牌識別模型 LPRNet&#xff08;License Plate Recognition via Deep Neural Networks&#xff09;是一種輕量級卷積神經網絡&#xff0c;專為端到端車牌識別設計&#xff0c;由Intel IOTG Computer Vision Group的Sergey Zherzdev于201…

No module named ‘sklearn‘

1、運行python數據分析庫時報錯 No module named sklearn2、原因 虛擬環境未安裝 sklearn 庫&#xff08;即 scikit-learn&#xff09;。 3、解決方案 pip install scikit-learn使用國內鏡像源&#xff1a; pip install scikit-learn -i https://mirrors.aliyun.com/pypi/simpl…