【Web开发】Vue2.0数据去重&Element-UI单选框

举报
zstar 发表于 2022/08/06 00:36:29 2022/08/06
【摘要】 问题场景 写vue2.0的时候遇到了这么一个场景:我需要再用户提交的表单中设置一个下拉式选框,方便用户选取。 具体选项则需要动态从后端数据库中获取。通过后端接口,我可以获得数据表中某一列的数据,但是这些...

问题场景

写vue2.0的时候遇到了这么一个场景:我需要再用户提交的表单中设置一个下拉式选框,方便用户选取。
具体选项则需要动态从后端数据库中获取。通过后端接口,我可以获得数据表中某一列的数据,但是这些利用循环来进行选项填充,就会出现重复选项,因此需要对重复数据进行去重。

数据去重

我的字段名是sex,可用这个函数进行去重。

    unique(arr) { // 根据唯一标识sex来对数组进行过滤
      const res = new Map();  //定义常量 res,值为一个Map对象实例
      //返回arr数组过滤后的结果,结果为一个数组   过滤条件是,如果res中没有某个键,就设置这个键的值为1
      return arr.filter((arr) => !res.has(arr.sex) && res.set(arr.sex, 1))
    }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

之后,只需要在其它动作函数中重复使用该函数即可。

Element-UI单选框填充

UI方面,使用了Element-UI做单选框。

        <el-form-item label="性别">
          <el-select clearable v-model="form.sex" placeholder="请选择性别" style="width: 100%" >
            <el-option v-for="item in sexs" :key="item.sex" :label="item.sex" :value="item.sex"></el-option>
          </el-select>
        </el-form-item>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

但是这段代码有个问题,使用时发现用户还没选择,就进行填充。
查阅Element的官方文档
发现clearable代表是否可以清空选项,默认为false,表示可以清空。
而我的数据表中设置了该字段记录不为null,因此导致了这个bug,去除clearable即恢复正常。

文章来源: zstar.blog.csdn.net,作者:zstar-_,版权归原作者所有,如需转载,请联系作者。

原文链接:zstar.blog.csdn.net/article/details/122935112

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。