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

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

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

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報(bào)錯(cuò)解決

項(xiàng)目中使用到了element-ui中的cascader級聯(lián)選擇器,組件下拉列表是動(dòng)態(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ù),這時(shí)cascader的options是[ ],下拉框是空的。

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

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

TypeError: Cannot read property 'level' of null

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

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

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

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

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
  });
}

二、編輯時(shí)給cascader賦值

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

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

[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就不會報(bào)錯(cuò),只要數(shù)據(jù)寫死就不會報(bào)錯(cuò),動(dòng)態(tài)賦值就報(bào)錯(cuò)。

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

真讓人摸不著頭腦。 

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

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

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

當(dāng)然,選中了節(jié)點(diǎn)同樣會報(bào)錯(cuò),只要有activePath 就會報(bào)錯(cuò)。

[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,但是這樣有個(gè)缺陷就是不流暢,v-if設(shè)置為false時(shí)cascader的位置會空白,影響用戶體驗(yàn)。
  • 2、給cascader設(shè)置一個(gè)key,改變類型時(shí)也改變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
  });
}

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

    vue antd Form表單的使用及說明

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

    Nuxt的路由動(dòng)畫效果案例

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

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

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

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

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

    vue返回上一頁面時(shí)回到原先滾動(dòng)的位置的方法

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

最新評論