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

關(guān)于element中el-cascader的使用方式

 更新時間:2022年08月11日 09:55:21   作者:高級前端工程師全棧方向  
這篇文章主要介紹了關(guān)于element中el-cascader的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

element中el-cascader的使用

從后端拿到arr數(shù)據(jù)結(jié)構(gòu):

cityList: [
? ? {
? ? ? ? id: 1,
? ? ? ? name: '北京',
? ? ? ? child: [
? ? ? ? ? ? id: 11,
? ? ? ? ? ? name: '大興區(qū)',
? ? ? ? ? ? child: [
? ? ? ? ? ? ? ? id: 111,
? ? ? ? ? ? ? ? name: '亦莊'
? ? ? ? ? ? ]
? ? ? ? ]
? ? }
]

vue文件代碼

<template>
<el-cascader
    :options="cityList"
    :props="optionProps"
    v-model="selectedOptions"
    @change="handleChange">
</el-cascader>
</template>
<script>
data: {
    optionProps: {
        value: 'id',
        label: 'name',
        children: 'child'
    }
}
</script>

使用el-cascader報錯解決

項目中使用到了element-ui中的cascader級聯(lián)選擇器,組件下拉列表是動態(tài)的,根據(jù)用戶選擇的類型來從后臺請求數(shù)據(jù)

  <el-select v-model="type" @change="getCascader" placeholder="請選擇類型">
    <el-option
      v-for="item in type"
      :key="item.typeValue"
      :label="item.typeName"
      :value="item.typeValue"
    />
  </el-select>
  <el-cascader
    :options="cascaderOption"
    :props="props"
    v-model="cascaderValue"
    collapse-tags
    :placeholder="請先選擇類型"
  />

再根據(jù)后臺獲取的數(shù)據(jù),加載級聯(lián)選擇器

getCascader() {
  this.cascaderValue= []      
  getCascader(this.type).then(response => {
    this.cascaderOption = response.data.data
  });
}

于是就出現(xiàn)bug了

一、options為空的情況

場景:有的類型沒有數(shù)據(jù),這時cascader的options是[ ],下拉框是空的。

如果選擇了一個類型,根據(jù)類型獲取了cascader的數(shù)據(jù),在cascader中選擇了一條數(shù)據(jù),再更換類型,沒有這條數(shù)據(jù)了就會報錯

[Vue warn]: Error in callback for watcher "options": "TypeError: Cannot read property 'level' of null

TypeError: Cannot read property 'level' of null

根據(jù)報錯信息點進去看了一下,發(fā)現(xiàn)cascader有選中項的綁定值checkedValue和點擊的父節(jié)點(高亮)activePath , 即便設(shè)置了this.cascaderValue= [] ,cascader中的activePath還是有值,也就是點擊的父節(jié)點會被記錄下來,再次加載cascader找不到就會報錯。

解決:如果沒有數(shù)據(jù)就將cascader設(shè)置為不可編輯

<el-cascader
   :options="cascaderOption"
   :props="props"
   :disabled="optionsChanged"
   v-model="cascaderValue"
   collapse-tags
   :placeholder="showPlaceholder"
 />

并且直接return,不加載下拉節(jié)點

getCascader() {
  this.cascaderValue= []      
  getCascader(this.type).then(response => {
  if(response.data.data.length === 0){
      this.optionsChanged = true
      this.showPlaceholder = '暫無范圍'
      return
    }
    this.cascaderOption = response.data.data
  });
}

二、編輯時給cascader賦值

場景:cascader下拉節(jié)點的數(shù)據(jù)由后臺提供,編輯時的顯示值依然讓后臺提供,將后臺返回的信息直接賦值給cascaderthis.type = row.type //row為后臺返回的數(shù)據(jù)。

這樣賦值是可以顯示的,但是改變類型后,cascader的options又動態(tài)改變,這就導(dǎo)致了cascader的value在下拉節(jié)點中不存在,又跟一options為空的情況報了同樣的錯誤

[Vue warn]: Error in callback for watcher "options": "TypeError: Cannot read property 'level' of null

TypeError: Cannot read property 'level' of null

剛開始以為是后臺返回的數(shù)據(jù)有問題,將后臺返回的數(shù)組直接寫死賦值給cascader就不會報錯,只要數(shù)據(jù)寫死就不會報錯,動態(tài)賦值就報錯。

this.type = ['1','2']

真讓人摸不著頭腦。 

解決:叫上后臺一起排查后發(fā)現(xiàn)將返回的options中的value從string改成了int就可以了

三、點擊了父節(jié)點后改變了cascader的options

場景:后面又發(fā)現(xiàn)了一個bug,就是點擊了父節(jié)點但是并沒有選中的時候,改變了類型,options也動態(tài)改變了,改變后沒有這個父節(jié)點就會報錯。

當(dāng)然,選中了節(jié)點同樣會報錯,只要有activePath 就會報錯。

[Vue warn]: Error in callback for watcher "options": "TypeError: Cannot read property 'level' of null

TypeError: Cannot read property 'level' of null

解決:與一options為空的bug類似,重新渲染cascader都可以解決。

改變類型,cascader的options改變后,將cascader重新渲染。

重新渲染組件的方法有兩種:

  • 1、給cascader設(shè)置v-if,改變類型后,賦值options前將v-if設(shè)置為true就可以重新渲染cascader,但是這樣有個缺陷就是不流暢,v-if設(shè)置為false時cascader的位置會空白,影響用戶體驗。
  • 2、給cascader設(shè)置一個key,改變類型時也改變key值,key值改變了,cascader就會重新渲染
<el-cascader
	:key="isResouceShow"
   :options="cascaderOption"
   :props="props"
   :disabled="optionsChanged"
   v-model="cascaderValue"
   collapse-tags
   :placeholder="showPlaceholder"
 />
getCascader() {
  this.cascaderValue= []
  ++this.isResouceShow      
  this.showPlaceholder = '請先選擇所屬范圍'
  getCascader(this.type).then(response => {
	  if(response.data.data.length === 0){
	      this.optionsChanged = true
	      this.showPlaceholder = '暫無范圍'
	      return
	    }
  this.cascaderOption = response.data.data
  });
}

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

相關(guān)文章

  • vue computed的set方法無效問題及解決

    vue computed的set方法無效問題及解決

    這篇文章主要介紹了vue computed的set方法無效問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 使vue實現(xiàn)jQuery調(diào)用的兩種方法

    使vue實現(xiàn)jQuery調(diào)用的兩種方法

    這篇文章主要介紹了使vue實現(xiàn)jQuery調(diào)用的兩種方法 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • vue加載自定義的js文件方法

    vue加載自定義的js文件方法

    下面小編就為大家分享一篇vue加載自定義的js文件方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue.js下拉菜單組件使用方法詳解

    Vue.js下拉菜單組件使用方法詳解

    這篇文章主要為大家詳細介紹了Vue.js下拉菜單組件的使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • vue實現(xiàn)接口封裝的實現(xiàn)示例

    vue實現(xiàn)接口封裝的實現(xiàn)示例

    本文主要介紹了vue實現(xiàn)接口封裝的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • vue antd Form表單的使用及說明

    vue antd Form表單的使用及說明

    這篇文章主要介紹了vue antd Form表單的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Nuxt的路由動畫效果案例

    Nuxt的路由動畫效果案例

    這篇文章主要介紹了Nuxt的路由動畫效果案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 淺談VUE uni-app 條件編碼和頁面布局

    淺談VUE uni-app 條件編碼和頁面布局

    這篇文章主要介紹了uni-app 的條件編碼和頁面布局,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • Vue代理請求數(shù)據(jù)出現(xiàn)404問題及解決

    Vue代理請求數(shù)據(jù)出現(xiàn)404問題及解決

    這篇文章主要介紹了Vue代理請求數(shù)據(jù)出現(xiàn)404的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue返回上一頁面時回到原先滾動的位置的方法

    vue返回上一頁面時回到原先滾動的位置的方法

    這篇文章主要介紹了vue返回上一頁面時回到原先滾動的位置的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12

最新評論