位置: IT常识 - 正文

el-cascader数据渲染及回显至页面(以及踩坑历程+解决)(el-cascader数据渲染时不出现文字)

编辑:rootadmin
el-cascader数据渲染及回显至页面(以及踩坑历程+解决)

推荐整理分享el-cascader数据渲染及回显至页面(以及踩坑历程+解决)(el-cascader数据渲染时不出现文字),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:element cascader,el-cascader回显,element cascader,el-cascader懒加载回显,el-cascader-multi,elementui表格渲染数据,el-cascader-multi,el-cascader数据渲染时不出现文字,内容如对您有帮助,希望把文章链接给更多的朋友!

第一次使用el-cascader就把坑踩了个遍,写个记录,也希望能够帮助到同为小猿的你们。

下面是我写的一个还原项目的例子

Bug1  首先是最小子集仍然有children,但是children为空数组,el-cascader渲染时,发现有children所以继续渲染了,只是没数据

<el-cascader :props="defaultParams" :options="options" v-model="form.selectedOptions" > </el-cascader>//option是要选择的数据 options: [ { id: "1", name: "水果", level: "1", pid: "0", status: "1", sub: [ { id: "4", name: "苹果", level: "2", pid: "1", status: "1", sub: [ { id: "41", name: "红富士", level: "2", pid: "1", status: "1", sub: [], }, { id: "42", name: "元帅", level: "2", pid: "1", status: "1", sub: [], }, ], }, { id: "8", name: "香蕉", level: "2", pid: "1", status: "1", sub: [], }, ], }, { id: "2", name: "食品", level: "1", pid: "0", status: "1", sub: [ { id: "5", name: "馒头", level: "2", pid: "2", status: "1", sub: [], }, { id: "6", name: "大米", level: "2", pid: "2", status: "1", sub: [], }, ], }, ],

我这里的sub相当于children,可以看到我最小的子集,仍有sub:[ ] ,导致渲染空

解决:处理源数据(这里源数据☞  options),我看其他解决方式是将为空的children赋值为undefine,也有直接处理源数据,取出要用的数据,这里我把两种方式都写下来,可以择一使用,

el-cascader数据渲染及回显至页面(以及踩坑历程+解决)(el-cascader数据渲染时不出现文字)

第一种:

// 递归判断列表,把最后的sub设为undefined sub也就是源数据里的children getTreeData(data) { for (var i = 0; i < data.length; i++) { if (data[i].sub.length < 1) { // sub若为空数组,则将sub设为undefined data[i].sub = undefined; } else { // sub若不为空数组,则继续 递归调用 本方法 this.getTreeData(data[i].sub); } } return data; },

第二种是将源数据过滤掉children,把主要数据取出来,放在一个新数组,这样就得到一个新的没有children的数组了,在使用时调用该方法就可以啦

getTreeData(datas) { let data = []; datas.map((item) => { if (item.sub.length > 0) { let dadax = { label: item.name, //这是需要展示的数据 我的数据是name,所以label对应的是name value: item.id, sub: this.getTreeData(item.sub), }; data.push(dadax); } else { let dadax = { label: item.name, value: item.id, }; data.push(dadax); } return data; }); return data; },

Bug2    在做数据回显时,总是回显不出数据,找遍了各种方式还是没解决,到后来才发现在props里多加了个属性,导致不回显数据

下面,先说数据是怎么回显的,其实很简单,只需要后端把对应的层级关系的节点id就可以啦

例如我的   尤其要特别注意 给后端大佬说清 需要的数据格式 是 一个大的数组 里面是一个一个的小数组,一个数组代表了一个回显的数据,我这里做的是多选的,所以回显的数据比较多,这里以两个为例,多个回显数据就很多几条数组就可以啦   

 tips:在找其他答案的时候偶然发现也可以通过官方文档的getCheckedNodes方法来拿到选择过的数据然后再用v-model来绑定,也可以回显数据,这个方法我没试,应该也是可以的

 接下来,就要说说我踩得冤坑了,主要还是不熟悉el-casasder组件,乱加属性emitPath:false,这里是解决项目字段和组件字段不对应的方式,el-cascader默认显示的字段是label

 如果想具体了解下emitPath的用法可以参考element-ui的官网  

 到此,算是对el-cascader的使用告一段落了,有缺失的地方,也希望多多补充,觉得可以的话,就给俺点个赞吧

本文链接地址:https://www.jiuchutong.com/zhishi/283555.html 转载请保留说明!

上一篇:npm info: node: --openssl-legacy-provider is not allowed in NODE_OPTIONS

下一篇:win10蓝牙共享网络怎么用(win10蓝牙共享网络给手机)

  • 红米k40像素是多少(红米k 40像素)

    红米k40像素是多少(红米k 40像素)

  • ipad锁屏喜马拉雅播放就暂停(ios12取消喜马拉雅锁屏界面)

    ipad锁屏喜马拉雅播放就暂停(ios12取消喜马拉雅锁屏界面)

  • 携程取消抢票会扣钱吗(携程取消抢票会怎么样)

    携程取消抢票会扣钱吗(携程取消抢票会怎么样)

  • 微信聊天记录莫名其妙没了怎么回事(微信聊天记录莫名其妙少了一部分)

    微信聊天记录莫名其妙没了怎么回事(微信聊天记录莫名其妙少了一部分)

  • 笔记本充电到95就不充了(笔记本充电到95不充电了怎么回事)

    笔记本充电到95就不充了(笔记本充电到95不充电了怎么回事)

  • 美团otc是什么订单(美团oc是什么意思)

    美团otc是什么订单(美团oc是什么意思)

  • tcp和udp是哪一层的协议(tcp/udp属于什么层)

    tcp和udp是哪一层的协议(tcp/udp属于什么层)

  • 微信能一直加一个人吗(微信一直加一个人频繁要等多久)

    微信能一直加一个人吗(微信一直加一个人频繁要等多久)

  • e6600cpu配什么主板(e6600cpu能装win7吗)

    e6600cpu配什么主板(e6600cpu能装win7吗)

  • 美团买了会员能退吗(美团会员买完之后可以退款吗)

    美团买了会员能退吗(美团会员买完之后可以退款吗)

  • 电脑上怎样下载歌曲到u盘(电脑上怎样下载搜狗输入法)

    电脑上怎样下载歌曲到u盘(电脑上怎样下载搜狗输入法)

  • 怎么延长华为锁屏设置(华为怎么延长锁屏)

    怎么延长华为锁屏设置(华为怎么延长锁屏)

  • 索尼相机传照片的app叫什么(索尼相机传照片到手机)

    索尼相机传照片的app叫什么(索尼相机传照片到手机)

  • 苹果手机可以拉黑对方号码吗(苹果手机可以拉黑座机号码吗)

    苹果手机可以拉黑对方号码吗(苹果手机可以拉黑座机号码吗)

  • kirin710f是什么意思(kirin710f处理器性能)

    kirin710f是什么意思(kirin710f处理器性能)

  • 网络地址和ip地址区别(网络地址和ip地址有什么区别)

    网络地址和ip地址区别(网络地址和ip地址有什么区别)

  • 电脑什么都没开内存90%以上(电脑什么都没开cpu使用率高)

    电脑什么都没开内存90%以上(电脑什么都没开cpu使用率高)

  • iphone11怎么呼叫siri(苹果11怎么设置呼叫手机号)

    iphone11怎么呼叫siri(苹果11怎么设置呼叫手机号)

  • 华为mate30支持双卡吗(华为mate30支持双系统吗)

    华为mate30支持双卡吗(华为mate30支持双系统吗)

  • 苹果8怎么调横屏幕(苹果8怎么调横屏)

    苹果8怎么调横屏幕(苹果8怎么调横屏)

  • 怎么投诉淘宝卖家未按时间约定发货(怎么投诉淘宝卖家 怎么投诉淘宝卖家不发货)

    怎么投诉淘宝卖家未按时间约定发货(怎么投诉淘宝卖家 怎么投诉淘宝卖家不发货)

  • 无需物流发货什么意思(无需物流发货会有什么处罚)

    无需物流发货什么意思(无需物流发货会有什么处罚)

  • 乐视手机开不了机怎么办(乐视手机开不了机怎么办亮红灯)

    乐视手机开不了机怎么办(乐视手机开不了机怎么办亮红灯)

  • 推荐几个免费的微信公众号第三方管理平台(推荐几个免费的喜剧电影)

    推荐几个免费的微信公众号第三方管理平台(推荐几个免费的喜剧电影)

  • vivo手机怎么隐藏下载的应用(vivo手机怎么隐藏下面三个键)

    vivo手机怎么隐藏下载的应用(vivo手机怎么隐藏下面三个键)

  • vivo21电源键在哪(vivox21a电源键坏了怎么办)

    vivo21电源键在哪(vivox21a电源键坏了怎么办)

  • mqtt是什么

    mqtt是什么

  • 汽车保养 美容
  • 价外费用纳税义务发生时间
  • 个人独资企业怎么取钱
  • 印花税计入税金及附加吗
  • 预扣预缴和汇算清缴
  • 滴滴能出票吗
  • 预收账款借方余额可以计入应收账款的哪方
  • 客户逾期付款
  • 基金收入交增值税吗
  • 购货发票属于外来原始凭证吗为什么
  • 月末哪些科目需要手动结转为成本
  • 增值税系统技术维护费记什么科目
  • 运输公司结转成本
  • 新公司成立前期人员配置
  • 公司购买银行理财产品会计分录怎么写
  • 餐饮公司如何挣钱
  • 专用发票包括增值税吗
  • 企业所得税税收优惠方式有哪些
  • 一般纳税人进项税额转出会计分录
  • 电子发票详见清单怎么开
  • 如何降低房租
  • 购买房产,税费怎么计算
  • 购买银行承兑汇票的会计分录
  • 虚开普票是不是很普遍
  • Win11安装如何跳过以太网
  • 偶然所得怎么缴纳个人所得税免税
  • 内部交易逆流如何算利润
  • 财务报表利润表怎么填
  • 小型微利企业的企业所得税优惠政策
  • 公司帐户能直接转账吗
  • 支付挂靠方的管理费用有进项吗?
  • 总公司拨给分公司的钱怎么平账
  • vue如何配置环境变量
  • php删除数据
  • 微前端Qiankun介绍
  • php 序列化函数
  • ssm算前后端分离吗
  • html转化成图片
  • sap abap入门
  • 2022年终总结
  • 企业资产损失税前扣除管理办法最新
  • phpcms怎么样
  • 异地预缴的附加税在申报税时会抵消掉么
  • 设置sql server的安全认证模式为混合认证模式
  • 长期股权投资会计准则2021修订
  • 企业增资会计科目
  • 不交社保的职业
  • 增值税涉及的税目有哪些
  • 年度汇算清缴缴税的会计分录
  • 货样广告品出口如何申报
  • 两笔不同业务能转账吗
  • 会计核算是否健全划分为
  • 单位社保缴费基数比例
  • 对公账户明细入账怎么查
  • 应收账款是净额列示吗
  • 职工薪酬的范围及内容
  • 建账固定资产的期初科目是什么
  • windows 10的安装
  • 绿色安装包怎么卸载
  • win7系统如何隐藏桌面
  • fedora os
  • 老毛桃U盘装系统综合教程
  • win10系统如何快速打开控制面板
  • linux find命令详解xargs
  • 重装系统 xp
  • win7系统无法安装谷歌怎么办
  • lsm.exe是什么程序
  • linux小技巧
  • linux扩充inode
  • windows7 sp1升级包
  • python编程模拟
  • shell监控文件
  • js出错
  • 网络传输协议是事实上的国际标准
  • 如何在python中运行程序
  • android新手入门
  • js utf-8编码转换中文
  • unity的shader用法
  • javascript的基础类型有哪些
  • 我们是小规模纳税人,有个人所得税代扣代缴的业务吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设