当前位置: 首页 > article >正文

字典如何与选择器一起使用

背景:开发过程中会遇到某些字段需要做成下拉框。如下图:

 组件 | Element里有select选择器这个组件可以实现下拉框的效果

我们可能会想到创一个辅助表来存储这些下拉数据像这样

这样虽然能实现,但是在实际开发中是不合理的,如果有多的表的多个字段都需要用到下拉框,就需要创建很多的辅助表。并且下拉框都有一个特点,就是键值对的存在。我们就引入了字典

这是一个字典,里面有字典名称、字典项、字典值,可以实现动态选择,且多个表多个字段需要用到的数据都可以在字典里先添加一个字典名称,再添加对应的字典项和字典值(key-value)。

具体字段设计如下:

后端字典这个类里有三个重要的接口

1.获取某个字典内所有的字典项,提供给前端的select组件使用

/**
     * 获取某个字典内所有的字典项,提供给前端的select组件使用
     */
    @GetMapping("/getDictValues/{code}")
    public R getDictValues(@PathVariable("code") String code){
        QueryWrapper<SysDictEntity> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("type", 2);
        queryWrapper.eq("code", code);
        queryWrapper.orderByAsc("sort");
        List<SysDictEntity> list = sysDictService.list(queryWrapper);
//        System.out.println(list);
        List<Map<String,String>> returnMap = new ArrayList<>();
        list.forEach(x->{
            Map<String,String> newMap = new HashMap<>();

            newMap.put("value", x.getValue());
            newMap.put("label", x.getName());
            returnMap.add(newMap);
        });
        return R.ok().put("dict", returnMap);
    }

前端调用这个接口拿到某个字典里的所有字典项以汽车品牌为例展示

 <el-form-item label="品牌" prop="brand">
        <el-select
          v-model="dataForm.brand"
          placeholder="请选择品牌"
          :disabled="dataForm.id !== 0" >
         <!--  :value=""是传给这个表单项prop="brand"的值 -->
          <el-option
            v-for="item in options"
            :key="item.value"
            clearable
            :label="item.label"
            :value="item.value"
            >
        </el-option>
        </el-select>
       
      </el-form-item>
this.$http({
          url: this.$http.adornUrl('/sys/dict/getDictValues/brand'),
          method: 'get',
          params: this.$http.adornParams()
        }).then(({data}) => {
          //console.log(data);
          if (data && data.code === 0) {
            this.options = data.dict
          }
        })

就完成了字典以select的绑定,但是有一个问题,  选择器:value的值传给这个表单项prop="brand"的值,brand拿到的是key值。(下表value对应map集合里的key、lable对应value)

 

 所以我们的展示页面品牌这列展示的都是数字,如何展示对应的lable呢?这就用到了字典里的第二个接口。

2.传入code值,获取这个字典中所有的字典项,并且以map集合的方式传回,前端table组件展示使用。

/**
     * 传入code值,获取这个字典中所有的字典项,并且以map集合的方式传回,前端table组件展示使用
     * @param code
     * @return
     */
    @GetMapping("/getAllDictValues/{code}")
    public R getAllDictValues(@PathVariable("code") String code){
        QueryWrapper<SysDictEntity> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("type", 2);
        queryWrapper.eq("code", code);
        queryWrapper.orderByAsc("sort");
        List<SysDictEntity> list = sysDictService.list(queryWrapper);
        Map<String,String> returnMap = new HashMap<>();
        list.forEach(x->{
            returnMap.put(x.getValue(), x.getName());
        });
        return R.ok().put("dict", returnMap);

    }

 

 展示页面通过传入code值,获取这个字典中所有的字典项,并且以map集合的方式传回,这个接口,将接收到的数据 data.dict赋值给this.carBrandAll ,carBrandAll定义的一个全局对象。

 //获取所有品牌
    getCarBrand() {
        this.$http({
          url: this.$http.adornUrl('/sys/dict/getAllDictValues/brand'),
          method: 'get',
          params: this.$http.adornParams(
          )
        }).then(({data}) => {
          
          if (data && data.code === 0) {
            this.carBrandAll = data.dict
            
          }
        })
      },

表单项通过插槽拿到对应brand的值(key)到carBrandAll对象里找到对应的 lable(value)l实现页面展示值

<el-table-column
        prop="brand"
        header-align="center"
        align="center"
        width="80"
        label="品牌">
        <template slot-scope="scope">
          <span>{{ carBrandAll[scope.row.brand] }}</span>
        </template>
      </el-table-column>

3.传入code,value值,获取这个字典中对应的字典name值(在这里和选择器一起使用过程中没用到,就不过多讲。)

/**
     * 传入code,value值,获取这个字典中对应的字典name值
     * @return
     */
    @GetMapping("/getAllDictNameByValue")
    public R getAllDictNameByValue(@RequestParam Map<String, Object> params){
        String code = (String)params.get("code");
        String value = (String)params.get("value");
        if (StringUtils.isNotBlank(code) &&StringUtils.isNotBlank( value) ) {
            QueryWrapper<SysDictEntity> queryWrapper = new QueryWrapper<>();
            queryWrapper.eq("type", 2);
            queryWrapper.eq("code", code);
            queryWrapper.eq("value", value);
            queryWrapper.last("limit 1");
            SysDictEntity sysDict = sysDictService.getOne(queryWrapper);
            return R.ok().put("name", sysDict.getName());
        }
        return R.error();
    }

总结:字典不光可以和选择器一起使用,单选框、多选框这些都可以看作key-value的形式,下次在讲解字典和其他组件使用。 


http://www.kler.cn/a/353922.html

相关文章:

  • SpringBoot插件
  • tomcat12启动流程源码分析
  • jenkins入门12-- 权限管理
  • Python 爬虫验证码识别
  • [项目实战2]贪吃蛇游戏
  • atrust异常导致ERR_NETWORK_CHANGED
  • Neo4j 构建文本类型的知识图谱
  • 大数据开发基础实训室设备
  • 学习索引时想到的问题
  • 结直肠癌数据集(不定期更新)
  • 中航资本:什么条件才能买创业板股票,创业板权限开通详解!
  • 使用python实现学生成绩管理系统
  • Java爬虫:API接口数据爬取入门详解及示例代码
  • 视频的编解码格式
  • 分享如何网上找饭搭子一起品尝美食,分享快乐,建立深厚友谊
  • Leetcode—1114. 按序打印【简单】(多线程)
  • VR线上展厅:超越时空的沉浸式展览,打造个性化、高效展览新模式
  • el-select 下拉框选项文字过长解决方案
  • Chromium html<script>对应c++接口定义
  • 洗衣店数字化转型:Spring Boot订单管理
  • Web前端高级工程师培训:异步处理专题
  • 基于机器学习与深度学习的贷款批准预测
  • Vue 3 和 Vue 2区别
  • 若依框架中spring security的完整认证流程,及其如何使用自定义用户表进行登录认证,学会轻松实现二开,嘎嘎赚块乾
  • 开发中众多框架的个人理解,Unity设计模式,MVC,MVVM框架
  • 【WebGIS实例】怎么将GCJ02坐标系的经纬度转换为WGS84坐标系?