import{_ as s,o as a,c as n,V as l}from"./chunks/framework.b31a4d00.js";const E=JSON.parse('{"title":"@fesjs/plugin-enums","description":"","frontmatter":{},"headers":[],"relativePath":"reference/plugin/plugins/enums.md"}'),p={name:"reference/plugin/plugins/enums.md"},o=l(`

@fesjs/plugin-enums

介绍

日常业务开发中,有很多场景会使用到枚举值,比如 select-options、table-column。

该插件提供统一的枚举存取及丰富的函数来处理枚举。

启用方式

package.json 中引入依赖:

json
{
    "dependencies": {
        "@fesjs/fes": "^3.0.0",
        "@fesjs/plugin-enums": "^3.0.0"
    }
}

配置

静态配置

.fes.js 中配置:

js
// 配置格式:[[key, value], ...]
export default {
    enums: {
        status: [
            ['0', '无效的'],
            ['1', '有效的'],
        ],
    },
};

动态配置

在业务代码中

js
import { enums } from '@fesjs/fes';
// 动态添加
enums.push('status', [['0', '无效的'], ['1', '有效的']]
enums.get('status', '1') // 有效的

场景使用

vue
<template>
    <div>
        <!-- 遍历枚举status -->
        <div v-for="item in enumsGet('status')" :key="item.key">{{ item.value }}:{{ item.key }}</div>
        <!-- 遍历枚举扩展后的roles -->
        <div v-for="item in roles" :key="item.key">{{ item.name }}:{{ item.disabled }}</div>
        <!-- 获取枚举roles为2的英文名 -->
        <div>{{ enumsGet('roles', '2', { dir: 'eName' }) }}</div>
    </div>
</template>
<script>
import { enums } from '@fesjs/fes';

export default {
    setup() {
        // 动态添加枚举,枚举项是对象,并指定key的属性名为id
        enums.push(
            'roles',
            [
                {
                    id: '1',
                    cName: '系统管理员',
                    eName: 'System',
                    perm: ['1', '2', '3'],
                },
                {
                    id: '2',
                    cName: '业务管理员',
                    eName: 'Business',
                    perm: ['1', '2'],
                },
                {
                    id: '3',
                    cName: '普通用户',
                    eName: 'User',
                    perm: ['1'],
                },
            ],
            { keyName: 'id' },
        );
        // 导出定制格式的roles,扩展枚举项新的属性name、disabled
        const roles = enums.get('roles', {
            extend: [
                {
                    key: 'name',
                    dir: 'cName', // 指定取值路径,取属性cName的值
                },
                {
                    key: 'disabled',
                    // 传入函数,获取结果值
                    transfer: (item) => item.value.perm.some((i) => i >= 2),
                },
            ],
        });
        console.log(roles);
        // [{key: '1', name: '系统管理员', disabled: true, value: {...}}, ....]
        return {
            enumsGet: enums.get,
            roles,
        };
    },
};
</script>

API

get

js
get('status');
get('status', '1');
get('status', {
    extend: [
        {
            key: 'name',
            dir: 'value',
        },
        {
            key: 'disabled',
            transfer: (item) => item === '0',
        },
    ],
});
get('status', '1', { dir: 'value' });

push

动态添加枚举,重复添加会覆盖

枚举项为数组,枚举项的[0]解析为 key,枚举项的[1]解析为 value

枚举项为对象时,根据 opt 配置 keyName、valueName 取枚举项属性值分别作为 key 和 value,如果valueName未设置则value就是枚举项

remove

移除指定的枚举

concat

基于现有的枚举,连接上新的枚举后返回新的枚举

convert

将传入的枚举格式转换为{key, value}的形式

extend 配置

扩展枚举项属性的配置

js
get('status', {
    extend: [
        {
            key: 'name',
            dir: 'value',
        },
        {
            key: 'disabled',
            transfer: (item) => item.key === '0',
        },
    ],
});

dir 规则

dir 是指定枚举项 value 的取值方式,规则如下:

js
// 假如枚举项value的结构如下
const user = {
    age: 18,
    name: 'aring',
    role: [
        {
            id: 1,
            name: '管理员'
        },
                    {
            id: 2,
            name: '业务操作员'
        }
    ]
}
// 那么规则解析是:
dir              value
'age'        =>  18
'role[0]'    =>  {id: 1, name: '管理员'}
'role[1].id' =>  2

TIP

枚举项 value 如果是基本类型,则规则不生效,value 就是当前值

`,44),e=[o];function t(c,r,D,F,y,i){return a(),n("div",null,e)}const A=s(p,[["render",t]]);export{E as __pageData,A as default};