欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Element中select多數據加載優(yōu)化的實現

 更新時間:2021年09月26日 16:17:07   作者:下落香樟樹  
本文主要介紹了Element中select多數據加載優(yōu)化的實現,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

場景

近期著手開發(fā)基于ElementUI的后臺管理系統(tǒng),偶然間發(fā)現「el-select」下拉選擇時候遇到一個問題,當渲染下拉選項的「options」的數據量過多時「本項目中的數據條目已過萬」,就會出現下拉選擇器卡頓的情況,尤其是在模糊匹配過濾的情況下,顯得十分的卡頓。初始化選擇器的時候,也會點擊無反應,有時候需要點擊多次才可出現「dialog」彈窗(本次下拉篩選在彈窗中實現)。 翻閱多篇博客筆記之后,最終找到一個可以解決問題的方案,現將此次優(yōu)化方案記錄成為筆記,以便于日后遇到類似問題的時候便于查閱。

注:基于select的下拉篩選,通過自定義事件來實現模糊搜索匹配。

一共兩種方案:

  • 一是獲取所有數據,通過輸入的關鍵字自己對獲取的數據進行過濾處理;
  • 二是通過輸入的關鍵字來動態(tài)請求后臺接口,通過接口返回的數據來動態(tài)渲染下拉選項;

代碼實現

Vue組件實例

<template>
  <div class="app">
    <el-dialog title="標題" :visible.sync="relatedOpen" :append-to-body="true" width="500px">
      <el-row :gutter="16">
        <el-col :span="20">
          <el-select
            v-model="value"
            filterable
            clearable
            style="width:100%"
            placeholder="請選擇"
            :loading="searchLoad"
            :filter-method="filterMethod"
            v-el-select-loadmore="loadMore(rangeNumber)"
            @visible-change="visibleChange"
          >
            <el-option v-for="item in options.slice(0, rangeNumber)" :key="item.key" :label="item.value" :value="item.key"></el-option>
          </el-select>
        </el-col>
        <el-col :span="4">
          <el-button type="primary" @click="submit">確定</el-button>
        </el-col>
      </el-row>
    </el-dialog>
  </div>
</template>
  • 「v-el-select-loadmore」為自定義指令封裝的數據加載指令,是為了解決和優(yōu)化elementUI下拉選擇器加載數據過多出現卡頓問題的。
  • 「filter-method」是下拉選擇器的一個自定義屬性,可以監(jiān)聽輸入的變量,從而依據變量來實現數據的動態(tài)獲?。?/li>
  // 自定義指令
  directives: {
    "el-select-loadmore": (el, binding) => {
      // 獲取element UI定義好的scroll元素
      const SELECTWRAP_ROM = el.querySelector(".el-select-dropdown .el-select-dropdown__wrap");
      if (SELECTWRAP_ROM) {
    // 添加scroll事件
        SELECTWRAP_ROM.addEventListener("scroll", function() {
      // 判斷滾動
          const condition = this.scrollHeight - this.scrollTop <= this.clientHeight;
          condition && binding.value();
        });
      }
    }
  }

相應的數據函數

export default {
  data() {
    return {
      relatedOpen: false,
      options: [] /* 選擇下拉框的值 */,
      courseList: [],
      rangeNumber: 10,
      searchLoad: false /* 下拉框的loading狀態(tài) */,
      value: "",
      timer: null
    };
  },
  created() {
    this.getOptions();
  },
  methods: {
    // 按需加載
    loadMore(n) {
      return () => (this.rangeNumber += 5);
    },
    // 過濾課件
    filterMethod(query) {
      if (this.timer != null) clearTimeout(this.timer);
      !this.searchLoad && (this.searchLoad = true);
      this.timer = setTimeout(() => {
        this.options = !!query ? this.courseList.filter(el => el.value.toLowerCase().includes(query.toLowerCase())) : this.courseList;
        clearTimeout(this.timer);
        this.searchLoad = false;
        this.rangeNumber = 10;
        this.timer = null;
      }, 500);
    },
    // 監(jiān)聽select下拉框的顯示和隱藏
    visibleChange(flag) {
      // 顯示時初始化列表
      flag && this.filterMethod("");
      // 初始化默認值
      this.rangeNumber = 10;
    },
    // 獲取選項
    async getOptions() {
      await searchCourseware().then(res => {
        let list = res.data || [];
        // 默認展示的數據
        this.options = list;
        // 原始數據
        this.courseList = list;
      });
    }
  }
}

注:

  • 定時器作用是防止輸入篩選的關鍵字太過頻繁,從而造成數據響應不及時;因為本次是一次性獲取了全部的數據,所以這里只是用做渲染加載數據;
  • 選擇器的事件函數主要是用來初始化“獲取焦點”和“失去焦點”時處理默認展示數據用的,若是獲取的網絡請求,此處需要做“函數截流”處理;目的是減少接口請求次數。

總結:

換了新的工作環(huán)境,現開始著手做后臺管理系統(tǒng),或多或少會遇到各種各樣的問題。一如即往,會在筆記中記錄開發(fā)中遇到的問題。好記性不如爛筆頭,希望現在埋下種子,等到來年秋天的時候會收獲🍒果實。JY

到此這篇關于Element中select多數據加載優(yōu)化的實現的文章就介紹到這了,更多相關Element select多數據加載內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue 2.0 偵聽器 watch屬性代碼詳解

    Vue 2.0 偵聽器 watch屬性代碼詳解

    這篇文章主要介紹了Vue 2.0 偵聽器 watch屬性代碼詳解,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-06-06
  • Vue源碼學習之數據初始化

    Vue源碼學習之數據初始化

    這篇文章主要為大家介紹了Vue源碼學習之數據初始化實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vuex頁面刷新數據丟失問題的四種解決方式

    vuex頁面刷新數據丟失問題的四種解決方式

    vuex是大家使用vue時大多數都會選擇的,但是當頁面刷新之后vuex數據會丟失,下面這篇文章主要給大家介紹了關于vuex頁面刷新數據丟失問題的四種解決方式,需要的朋友可以參考下
    2022-02-02
  • Element Table 自適應高度的實現示例

    Element Table 自適應高度的實現示例

    el-table的高度不能適應不同電腦的分辨率,也不能跟隨瀏覽器的高度變化而變化的問題,本文就來解決一下Element Table 自適應高度,感興趣的可以了解一下
    2024-07-07
  • vite打包拆分js和css的配置指南

    vite打包拆分js和css的配置指南

    這篇文章主要給大家介紹了關于vite打包拆分js和css的配置指南,Vite是一個非??焖俚墓ぞ?它可以幫助你打包JavaScript文件,需要的朋友可以參考下
    2023-09-09
  • Vue實現滑動驗證功能

    Vue實現滑動驗證功能

    這篇文章主要為大家詳細介紹了Vue實現滑動驗證功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • vue單頁面應用部署配置詳解

    vue單頁面應用部署配置詳解

    本文主要介紹了vue單頁面應用部署配置詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • 詳解vue+vuex+koa2開發(fā)環(huán)境搭建及示例開發(fā)

    詳解vue+vuex+koa2開發(fā)環(huán)境搭建及示例開發(fā)

    本篇文章主要介紹了詳解vue + vuex + koa2開發(fā)環(huán)境搭建及示例開發(fā),小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • 快速入門Vue

    快速入門Vue

    本篇文章主要介紹了如何快速入門Vue的方法,對0基礎學習Vue的朋友會很有幫助,跟著小編一起來看下吧
    2016-12-12
  • 你知道vue data為什么是一個函數

    你知道vue data為什么是一個函數

    本篇文章從javascript原型鏈來解釋為什么vue中data必須是一個函數,解釋一下這部分的原理內容,感興趣的朋友跟隨小編一起看看吧
    2021-11-11

最新評論