亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue2中的el-select組件數(shù)據(jù)太多,如何實現(xiàn)滾動加載數(shù)據(jù)效果

 更新時間:2024年04月25日 09:47:17   作者:艾苧  
這篇文章主要介紹了vue2中的el-select組件數(shù)據(jù)太多,如何實現(xiàn)滾動加載數(shù)據(jù)效果,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

項目場景

在我們平常開發(fā)中,我們的下拉框數(shù)據(jù)大部分都是后端一次性返回,然后前端直接塞到頁面渲染

我之前也是這么做的,但今天發(fā)現(xiàn)數(shù)據(jù)變得越來越多,已經(jīng)有五百多條了

所以我就決定著手優(yōu)化一下,怎么優(yōu)化呢

比如 分頁加載?虛擬列表?

問題描述

當(dāng)我們使用el-select下拉框選擇數(shù)據(jù)的時候,避免不了數(shù)據(jù)過多,導(dǎo)致一上來渲染到頁面會出現(xiàn)卡頓現(xiàn)象

比如說四五百條數(shù)據(jù),一下子塞到下拉框中,頁面剛開始渲染的時候

頁面許多地方都在渲染數(shù)據(jù)、重排、重繪,數(shù)據(jù)少還可以,數(shù)據(jù)太多會影響性能。

解決方案

el-select給我們提供了 支持遠(yuǎn)程搜索的功能,這樣我們可以一次渲染少許數(shù)據(jù),剩下數(shù)據(jù)可以通過搜索獲取。

但有時候 我不知道要搜索的數(shù)據(jù)名字叫什么,從而導(dǎo)致無法有效搜索,還有就是每次搜索都要請求一次數(shù)據(jù),其實官方這個優(yōu)化已經(jīng)解決大部分場景問題了。 

對于el-select的場景,顯然 虛擬列表 不是最優(yōu)的,因為虛擬列表會把視口外的元素從dom樹里移出去,導(dǎo)致我們選擇的數(shù)據(jù)狀態(tài)無法保存,所以我決定使用分頁加載 。

后端剛開始一次性把所有數(shù)據(jù)返回給我,然后前端分批進(jìn)行渲染,如果后端一次性請求所有數(shù)據(jù)太慢,也可以分批加載,具體可以與后端溝通。

代碼如下

一開始先拿20條數(shù)據(jù),渲染頁面,聲明一個變量保存所有數(shù)據(jù)

//html結(jié)構(gòu)
 <el-select v-model="hospital" @visible-change="visible" placeholder="請選擇醫(yī)院" filterable collapse-tags multiple @change='changeHospital'>
     <el-option :disabled="loading" :label="item.hospital_name" :value="item.hospital_id" v-for="(item,index) in hospitalList" :key="item.hospital_id"></el-option>
 </el-select>

//js代碼

 // 下拉框出現(xiàn)的時候事件
  visible(val){
 		 //如果多個下拉框,需要具體給某個標(biāo)簽綁定
        let scroll = document.querySelectorAll('.el-scrollbar__wrap')
        //顯示的時候綁定,隱藏的時候移出綁定事件
        if(val){
             scroll[1].addEventListener('scroll',this.scrollLoad)
        }else{
             scroll[1].removeEventListener('scroll',this.scrollLoad)
         }
   },
    // 下拉框滾動分頁加載數(shù)據(jù)
    scrollLoad(e){
         const { target: { clientHeight,scrollHeight,scrollTop } } = e
         const step = 100 //間隔,距離底部100的時候加載數(shù)據(jù)
         const len = this.hospitalList.length //獲取當(dāng)前展示的醫(yī)院列表長度
         if(len >= this.hospital_list.length)return //數(shù)據(jù)加載完畢
         //從總列表里每次 截取一段數(shù)據(jù),以便后期追加到頁面
         // 每次追加20條
         const data = this.hospital_list.slice(len,len + 20)
         //判斷觸底加載數(shù)據(jù)    
         if(clientHeight + scrollTop >= scrollHeight - step){
              this.hospitalList.push(...data)
              console.log('觸底加載數(shù)據(jù)');
         }
   }

如果感覺滾動監(jiān)聽太頻繁,可以加個節(jié)流處理,我這里沒有加

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論