vue若依框架dicts中字典项的使用:表格展示与下拉框示例

在若依框架的开发中,字典项的使用可以帮助我们更方便地管理和展示一些具有固定取值范围的数据,比如颜色类型、人员类型等。下面将详细介绍若依框架中字典项在表格和下拉框中的使用方法。

1. 若依字典项的配置

在若依框架中,我们首先需要在系统管理 - 字典管理中配置所需的字典。假设我们要配置两个字典:颜色(color)和人员类型(personnel_type)。具体配置如下:

颜色字典(color

字典标签 字典值
红色 1
蓝色 2
绿色 3

人员类型字典(personnel_type

字典标签 字典值
管理员 1
普通用户 2
访客 3

2. 在页面中引入字典

在 Vue 组件中,我们可以通过 dicts 属性引入需要使用的字典。示例代码如下:

复制代码
<template>
  <div>
    <!-- 表格部分 -->
    <el-table :data="tableData" style="width: 100%">
      <el-table-column
        :label="$t('h.ProductionColor')"
        align="center"
        prop="color"
      >
        <template slot-scope="scope">
          <dict-tag :options="dict.type.color" :value="scope.row.color">
          </dict-tag>
        </template>
      </el-table-column>
      <el-table-column
        :label="$t('h.personnelType')"
        align="center"
        prop="userType"
      >
        <template slot-scope="scope">
          <dict-tag :options="dict.type.personnel_type" :value="scope.row.userType">
          </dict-tag>
        </template>
      </el-table-column>
    </el-table>

    <!-- 下拉框部分 -->
    <el-form :model="formData" ref="formDataRef" label-width="120px">
      <el-form-item label="选择颜色">
        <el-select v-model="formData.color" placeholder="请选择颜色">
          <el-option
            v-for="item in dict.type.color"
            :key="item.dictValue"
            :label="item.dictLabel"
            :value="item.dictValue"
          >
          </el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="选择人员类型">
        <el-select v-model="formData.userType" placeholder="请选择人员类型">
          <el-option
            v-for="item in dict.type.personnel_type"
            :key="item.dictValue"
            :label="item.dictLabel"
            :value="item.dictValue"
          >
          </el-option>
        </el-select>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      tableData: [
        { color: "1", userType: "2" },
        { color: "2", userType: "1" }
      ],
      formData: {
        color: "",
        userType: ""
      },
      dicts: ["color", "personnel_type"]
    };
  },
  computed: {
    dict() {
      return this.$store.state.dict;
    }
  }
};
</script>

表格部分

在表格中,我们使用 dict-tag 组件来展示字典项。dict-tag 组件接收两个主要参数:

  • options:字典项的列表,通过 dict.type.colordict.type.personnel_type 获取。
  • value:当前行数据对应的字典值,通过 scope.row.colorscope.row.userType 获取。

下拉框部分

在下拉框中,我们使用 el-selectel-option 组件来实现选择功能。通过 v-for 指令遍历字典项列表,将每个字典项的 dictLabel 作为显示标签,dictValue 作为实际值。

数据获取

通过 computed 属性 dict 从 Vuex 中获取字典数据,确保在组件中可以方便地使用字典项。

相关推荐
顾安r9 分钟前
11.14 脚本网页 青蛙过河
服务器·前端·python·游戏·html
阿奇__19 分钟前
el-table有固定列时样式bug
vue.js·elementui·bug
LXA080928 分钟前
在Vue 3项目中配置和使用SCSS
vue.js·rust·scss
不爱吃糖的程序媛34 分钟前
Electron 智能文件分析器开发实战适配鸿蒙
前端·javascript·electron
Doro再努力39 分钟前
2025_11_14洛谷【入门1】数据结构刷题小结
前端·数据结构·算法
IT_陈寒1 小时前
SpringBoot 3.2新特性实战:这5个隐藏技巧让你的应用性能飙升50%
前端·人工智能·后端
flashlight_hi1 小时前
LeetCode 分类刷题:3217. 从链表中移除在数组中存在的节点
javascript·数据结构·leetcode·链表
Java追光着1 小时前
React Native 自建 JS Bundle OTA 更新系统:从零到一的完整实现与踩坑记录
javascript·react native·react.js
努力往上爬de蜗牛1 小时前
react native 运行问题和调试 --持续更新
javascript·react native·react.js
eason_fan2 小时前
Monorepo性能噩梦:一行配置解决VSCode卡顿与TS类型崩溃
前端·typescript·visual studio code