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

Posted zstar-_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Web开发Vue2.0数据去重&Element-UI单选框相关的知识,希望对你有一定的参考价值。

问题场景

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

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

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>

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

以上是关于Web开发Vue2.0数据去重&Element-UI单选框的主要内容,如果未能解决你的问题,请参考以下文章

Vue2.0的通用组件

饿了么基于Vue2.0的通用组件开发之路(分享会记录)

eleme饿了么vue项目随笔,随时更新,想到哪里写到哪里比较凌乱一直更新

Vue2.0 搭建Vue脚手架(vue-cli)

vue2.0开发时导入组件时出错

Weex基于Vue2.0开发框架模板搭建