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

vue中el-cascader三級聯(lián)動懶加載回顯問題解決

 更新時間:2023年06月16日 11:04:23   作者:liuwenjie_  
本文主要介紹了vue中el-cascader三級聯(lián)動懶加載回顯問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

李奶奶的,困擾了我兩個周的問題終于在今天得到了解決。神坑~~

如果你有幸刷到這篇文章,恭喜你,困擾你的問題總算有解決方法了。本篇文章解決你所有級聯(lián)懶加載回顯的問題和修改樣式不生效問題。

問題描述:

我的需求是調(diào)了三個下拉框接口進行關(guān)聯(lián)。在form表單里進行選擇傳值都是沒問題的。剛開始數(shù)據(jù)少沒有出現(xiàn)問題。第二天數(shù)據(jù)多了測試提了個bug,三級聯(lián)動竟然不顯示數(shù)據(jù)了。

 

然后就是兩個周的探索,夜不能寐啊。兩個周?。?!

網(wǎng)上給的方法各式各樣。甚至有說回顯必須有options,使用遞歸把options的數(shù)據(jù)填好進行回顯。純屬扯淡。

附上代碼

html:

        <el-cascader
          v-model="data.eventComboBoxValue"
          :props="cascaderProps"
          clearable
        />

js:

 cascaderProps() {
      return {
        lazy: true,
        lazyLoad: this.lazyLoad
      };
    }
methods:{
 async lazyLoad(node, resolve) {
      let level = node.level;
      let result;
      switch (level) {
        case 0: // 類型
          let initRes = await eventList();
          result = initRes.data.pageResult.list;
          break;
        case 1: //一級目錄
          let firstParams = {
            upstreamId: node.data.value
          };
          let firstRes = await eventList(firstParams);
          result = firstRes.data.pageResult.list;
          break;
        case 2: // 二級目錄
          let secondParams = {
            eventTypeId: node.data.value
          };
          let secondRes = await eventList(secondParams);
          result = secondRes.data.pageResult.list;
          result.forEach(item => {
            item.leaf = level >= 2;
          });
          break;
        default:
          result = [];
          break;
      }
      resolve(result);
    },
}

這樣是一般寫法,很多小伙伴這樣寫也不會有問題,但是看下請求數(shù)據(jù)的列表。某一個列表重復(fù)請求了多次。解決方法是在請求前加一層判斷,已經(jīng)有數(shù)據(jù)了就不要重復(fù)請求了。

if (node.children && node.children.length > 0) return;

到了這一步還是沒有回顯。仔細(xì)看你的數(shù)據(jù)是不是有重復(fù)項?比如第一層和第二層id一樣?恭喜你,遇到了和我一樣的問題。出現(xiàn)問題的原因是。cascader的每一項id都不能重復(fù),否則就不會進行下一層的加載了。和后端商量了幾種解決方案。給出最完美的方案。

請求列表的時候多傳一個自定義字段,我傳的是fromLinkage:1,讓后端知道我是在調(diào)級聯(lián)列表,這么做是為了不影響其他模塊下拉列表的功能。

 然后后端返回一個唯一標(biāo)識避免重復(fù),我們采用的是拼接列表名稱。

第一層返回

第二層返回

第三層返回 

把返回的這一項作為你的value值,這樣每一層的value都是唯一了。完美解決問題。正?;仫@。

至此有用過級聯(lián)el-cascader的伙伴都能解決問題了。那么點贊出門左轉(zhuǎn),可以摸魚啦~~

以下內(nèi)容偏傻瓜式教學(xué),供尚不能解決問題的新人參考。

綜上所述,我點擊第二層的時候傳參應(yīng)該傳id:3,但是現(xiàn)在傳了id:'upstreamid3',因為你原來的value值已經(jīng)綁定成了后端返回的key。value是從node中拿出來的,那我能不能拿到之前的3傳給后端呢?當(dāng)然可以。

 只需在你rosolve的數(shù)組里添加一個自定義字段,下一輪你就能從node中拿到你存的flag了!

第二層、第三層請求傳給后端。

總結(jié):一般這種回顯會出現(xiàn)在編輯、查看彈窗或者路由跳轉(zhuǎn)中,如果你的代碼還有問題不能回顯。彈窗或者新的頁面中中加個v-if每次關(guān)閉銷毀,獲取到詳情再創(chuàng)建即可。

如果解決了你的問題請點贊!點贊!讓我看看有多少被這個問題折磨的鐵子們~~~

另外新版本的element級聯(lián)會有一頁數(shù)據(jù)太多展示不下的問題,修改樣式竟然沒生效,我們會使用的是less,less穿透使用/deep/,scss穿透使用::v-deep。都不生效。

最終解決方案是把scope去掉,成功解決~

到此這篇關(guān)于vue中el-cascader三級聯(lián)動懶加載回顯問題解決的文章就介紹到這了,更多相關(guān)vue el-cascader懶加載回顯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • VSCode使React?Vue代碼調(diào)試變得更爽

    VSCode使React?Vue代碼調(diào)試變得更爽

    這篇文章主要為大家介紹了VSCode使React?Vue代碼調(diào)試變得更爽的使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 計算屬性和偵聽器詳情

    計算屬性和偵聽器詳情

    這篇文章主要介紹了計算屬性和偵聽器,文章以介紹計算屬性、偵聽器的相關(guān)資料展開詳細(xì)內(nèi)容,需要的朋友可以參考一下,希望對你有所幫助
    2021-11-11
  • 全站最詳細(xì)的Vuex教程

    全站最詳細(xì)的Vuex教程

    vuex是一個專門為vue.js設(shè)計的集中式狀態(tài)管理架構(gòu)。這篇文章主要介紹了全站最詳細(xì)的Vuex教程,需要的朋友可以參考下
    2018-04-04
  • Vue3+Canvas實現(xiàn)坦克大戰(zhàn)游戲(一)

    Vue3+Canvas實現(xiàn)坦克大戰(zhàn)游戲(一)

    這篇文章將利用Vue3和Canvas編寫一個童年經(jīng)典游戲—坦克大戰(zhàn),文中的示例代碼講解詳細(xì),感興趣的小伙伴快來跟隨小編一起學(xué)習(xí)一下吧
    2022-03-03
  • vue 的 Render 函數(shù)

    vue 的 Render 函數(shù)

    Vue 推薦在絕大多數(shù)情況下使用模板來創(chuàng)建你的 HTML。然而在一些場景中,你真的需要 JavaScript 的完全編程的能力。這時你可以用渲染函數(shù),它比模板更接近編譯器。下面就和小編一起來學(xué)習(xí)下面文章內(nèi)容吧
    2021-09-09
  • vue中子組件如何間接修改父組件傳遞過來的值問題

    vue中子組件如何間接修改父組件傳遞過來的值問題

    這篇文章主要介紹了vue中子組件如何間接修改父組件傳遞過來的值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue的表單數(shù)據(jù)收集案例之基本指令和自定義指令詳解

    vue的表單數(shù)據(jù)收集案例之基本指令和自定義指令詳解

    收集表單數(shù)據(jù)可以使用這個v-model實現(xiàn)這個數(shù)據(jù)的綁定,但是在有些輸入框中,還需要一些其他的指令搭配這個v-model指令結(jié)合使用,這篇文章主要介紹了vue的表單數(shù)據(jù)收集,基本指令和自定義指令,需要的朋友可以參考下
    2023-01-01
  • vue項目如何引入公共頭部底部

    vue項目如何引入公共頭部底部

    這篇文章主要介紹了vue項目如何引入公共頭部底部問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 一文詳解怎么安裝離線vue環(huán)境

    一文詳解怎么安裝離線vue環(huán)境

    這篇文章主要給大家介紹了關(guān)于怎么安裝離線vue環(huán)境的相關(guān)資料,由于公司要求在內(nèi)網(wǎng)開發(fā)項目,而內(nèi)網(wǎng)不能連接外網(wǎng),因此只能離線安裝vue環(huán)境,需要的朋友可以參考下
    2023-12-12
  • vue中window.onresize的使用解析

    vue中window.onresize的使用解析

    這篇文章主要介紹了vue中window.onresize的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論