vant Cascader级联选择实现可以选择任意一层级

 更新时间:2024年07月02日 09:03:10   作者:i紸定i  
这篇文章主要介绍了vant Cascader级联选择实现可以选择任意一层级方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

vant Cascader级联选择可以选择任意一层级

通过使用change事件,来实现选择任意一层级

<template>
  <div>
    <van-cascader
      :options="options"
      :value="selectedValue"
      @change="handleCascaderChange"
    ></van-cascader>
  </div>
</template>
data() {
  return {
    options: [
      { value: '1', label: 'Option 1', children: [...] },
      { value: '2', label: 'Option 2', children: [...] },
      ...
    ],
    selectedValue: [] // 记录选择值
  };
},
methods: {
  handleCascaderChange(value) {
    this.selectedValue = value;
  }
}

van-cascader 异步加载

异步加载选项

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

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

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

示例:

<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 里的字段名称。

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

监听change事件,动态设置options

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

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue实现商城购物车功能

    vue实现商城购物车功能

    这篇文章主要为大家详细介绍了vue实现商城购物车功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Vue实现滚动加载更多效果的示例代码

    Vue实现滚动加载更多效果的示例代码

    这篇文章介绍了在 Web 应用中处理大量数据展示的两种滚动加载更多方案,滚动加载更多通过分页工作,优点是实现简单、用户体验流畅,缺点是内存占用可能过高,虚拟列表只渲染视口内容,性能好但实现复杂,本文介绍了Vue实现滚动加载更多效果,需要的朋友可以参考下
    2024-12-12
  • vue + element动态多表头与动态插槽

    vue + element动态多表头与动态插槽

    这篇文章主要介绍了vue + element动态多表头与动态插槽,下面文章围绕vue + element动态多表头与动态插槽的相关资料展开文章的内容,具有一定的参考价值,需要的小伙伴可以参考一下,希望对大家有所帮助
    2021-12-12
  • vue-cli扩展多模块打包的示例代码

    vue-cli扩展多模块打包的示例代码

    本篇文章主要介绍了vue-cli扩展多模块打包的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • vue项目网站全局置灰功能实现示例详解

    vue项目网站全局置灰功能实现示例详解

    这篇文章主要为大家介绍了vue项目网站全局置灰功能实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 解决vue props 拿不到值的问题

    解决vue props 拿不到值的问题

    今天小编就为大家分享一篇解决vue props 拿不到值的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • vue easytable组件使用详解

    vue easytable组件使用详解

    Vue Easytable是一个基于Vue.js的数据表格组件库,它提供丰富的功能和灵活的配置,帮助开发者快速搭建复杂的数据表格界面,这篇文章主要介绍了vue easytable组件使用,需要的朋友可以参考下
    2023-09-09
  • Vue中使用Tiptap富文本编辑器的方法指南

    Vue中使用Tiptap富文本编辑器的方法指南

    Tiptap是一个无头(headless)的富文本编辑器框架,专为 Web 工匠设计,它提供了高度可定制和可扩展的编辑器功能,适用于各种前端框架,这篇文章主要介绍了Vue中使用Tiptap富文本编辑器的相关资料,需要的朋友可以参考下
    2026-02-02
  • vue双向数据绑定原理分析、vue2和vue3原理的不同点

    vue双向数据绑定原理分析、vue2和vue3原理的不同点

    这篇文章主要介绍了vue双向数据绑定原理分析、vue2和vue3原理的不同点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • 优化Vue页面中的表单布局和样式的技巧

    优化Vue页面中的表单布局和样式的技巧

    在日常开发中,Vue 项目中的表单布局和样式优化是一个重要的环节,通过合理的布局与美观的样式设计,不仅可以提升用户体验,还能增加页面的实用性和观赏性,本文将总结几个常见的表单和表格布局优化的技巧,需要的朋友可以参考下
    2024-10-10

最新评论