Enums利用类组件实现枚举
2023-12-14 17:59:10
class Enums {
constructor(enumsName) {
this.enumsName = enumsName;
this.data = {};
this.alias = []; //别名
}
//
set(name, value) {
this.data[name] = value + "";
return this;
}
// 根据name得到value
get(name) {
return this.data[name];
}
//根据value得到name
searchName(value) {
return Object.keys(this.data).find((name) => this.get(name) === value + "");
}
getData() {
return this.data;
}
setData(data) {
this.data = data;
return this;
}
getFirstValue() {
const data = this.getData();
return data[Object.keys(data)[0]];
}
setAlias(name) {
//设置别名
this.alias.push(name);
return this;
}
is(nameOrAlias) {
return this.enumsName === nameOrAlias || this.alias.includes(nameOrAlias);
}
clone() {
const cloneEnums = new Enums(this.enumsName);
const data = this.getData();
Object.keys(data).forEach((key) => {
cloneEnums.set(key, data[key]);
});
this.alias.forEach((aliasItem) => cloneEnums.setAlias(aliasItem));
return cloneEnums;
}
}
enums.js
import Enums from "util/Enums";
const enums = [
new Enums("是否").set("是", "1").set("否", "0"),
new Enums("性别").set("男", "1").set("女", "0"),
new Enums("启用禁用")
.setAlias("禁用启用")
.set("启用", "1")
.set("禁用", "0"),
];
export default (enumsName) => {
return enums.find((item) => item.is(enumsName));
};
export const getEnumsOption = (enumsName) => {
const data = enums.find((item) => item.is(enumsName)).data;
const option = [];
Object.keys(data).forEach((key) => {
option.push({ label: key, value: data[key] });
});
return option;
};
使用enums
import getEnums from "enums";
const settingTypeEnum = getEnums("启用禁用");
文章来源:https://blog.csdn.net/qq_60178319/article/details/134999370
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!