van-cascader 异步加载

vant官网

异步加载选项

在使用级联选择时当一次性拿到数据量太大时不仅接口慢而且前端渲染页面也会变慢,用户体验很不好,建议使用异步加载选项,

拿到的接口让后端返回一个是否还有下一级的判断,不然van-cascader判断没有children的时候会自动结束的

可以监听 change 事件并动态设置 options,实现异步加载选项。

示例:

javascript 复制代码
<van-popup v-model:show="showCascader" round position="bottom">
       <van-cascader
            v-if="showCascader"  // 加上这个是因为在企微侧边栏使用的时候,操作偶尔会出现tabs歪的情况
            v-model="formData.id"
            title="请选择xxx"
            :options="options"
            active-color="#1989fa"
            :field-names="fieldNames"
            @change="onChange"
            @close="showCascader = false"
            @finish="onFinish"
        />
</van-popup>

自定义字段名

后端定义的字段一开始可能不符合vant的默认字段,通过 field-names 属性可以自定义 options 里的字段名称。

javascript 复制代码
const fieldNames = {
      // 换成后端返回的你需要的对应字段
      text: 'name',
      value: 'id',
      children: 'children'
    };

监听change事件,动态设置options

javascript 复制代码
const onChange = ({value,selectedOptions}) => {
      getList({code:value}).then(res => { //请求接口
        res.data.map(item=>{
          if(item.children.length==0){ // 这个是和后端约定了如果没有子级,返回一个空数组,可以自己和后端约定一个可判断的值
            delete item.children
          }
        })
        addTree(selectedOptions, res.data, value)
      });
    };
   const addTree = (selectedOptions, children, id) =>{
      selectedOptions.forEach(item => {
        if (item.id=== id) {  // 注意这里是你要的value
          item.children = children
        }
      })
    }

这样就可以动态的获取到每一级下面的数据了

相关推荐
VOLUN9 分钟前
Vue3 中 watch 第三个参数怎么用?6 大配置属性 + 场景指南
前端·javascript·vue.js
远山枫谷38 分钟前
vue3通信组件学习小记
前端·vue.js
源码站~2 小时前
基于SpringBoot+Vue的健身房管理系统
vue.js·spring boot·后端·毕业设计·前后端分离·管理系统·健身房
天天向上10243 小时前
vue3 css使用v-bind实现动态样式
前端·css·vue.js
我只会写Bug啊10 小时前
Vue文件预览终极方案:PNG/EXCEL/PDF/DOCX/OFD等10+格式一键渲染,开源即用!
前端·vue.js·pdf·excel·预览
一 乐13 小时前
高校后勤报修系统|物业管理|基于SprinBoot+vue的高校后勤报修系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·毕设
薛一半15 小时前
Vue3的Pinia详解
前端·javascript·vue.js
前端付豪18 小时前
如何使用 Vuex 设计你的数据流
前端·javascript·vue.js
咖啡の猫18 小时前
Vue消息订阅与发布
前端·javascript·vue.js
爱看书的小沐19 小时前
【小沐杂货铺】基于Three.js绘制三维管道Pipe(WebGL、vue、react)
javascript·vue.js·webgl·three.js·管道·pipe·三维管道