vue項目中如何添加枚舉
更新時間:2022年09月14日 08:39:30 作者:loyd3
這篇文章主要介紹了vue項目中如何添加枚舉,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
vue項目添加枚舉
添加文件,文件名為enum.js
文件內(nèi)容:
//使用方法
/**
* 獲取枚舉值:STATUSMAP.SH
* 獲取枚舉描述:STATUSMAP.getDesc('SH')
* 通過枚舉值獲取描述:STATUSMAP.getDescFromValue('TG')
*/
let STATUSMAP = createEnum({
SH: [0, '審核中'],
TG: [1, '審核通過'],
});
function createEnum(definition) {
const valueMap = {};
const descMap = {};
for (const key of Object.keys(definition)) {
const [value, desc] = definition[key];
valueMap[key] = value;
descMap[value] = desc;
}
return {
...valueMap,
getDesc(key) {
return (definition[key] && definition[key][1]) || '無';
},
getDescFromValue(value) {
return descMap[value] || '無';
}
}
}
export default STATUSMAP;
在vue文件中引用
import STATUSMAP from "@/enum";
使用方法
在js中使用
//獲取枚舉值: STATUSMAP.SH //獲取枚舉描述: STATUSMAP.getDesc(‘SH') //通過枚舉值獲取描述: STATUSMAP.getDescFromValue(‘TG')
vue中枚舉的使用
涉及的場景:根據(jù)后端返回的字段匹配相應(yīng)的文字,進行頁面展示
1. 建一個js文件如:common.js
const enums = {
// 角色
roles: {
? ? ADMINISTRATOR: '管理人員',
? ? LEADER: '隊長'
? }
}
export {
? enums
? }2. 在頁面直接引入
html:
? ? <div class="table-detail">
? ? ? <el-table v-loading="loading" :data="list" height="222">
? ? ? ? <el-table-column label="序號" type="index">
? ? ? ? ? <template slot-scope="scope">
? ? ? ? ? ? {{ (pageNum - 1) * pageSize + scope.$index + 1 }}
? ? ? ? ? </template>
? ? ? ? </el-table-column>
? ? ? ? <el-table-column label="人員分工">
? ? ? ? ? <template slot-scope="scope">
? ? ? ? ? ? {{ enums.roles[scope.row.roles] }}
? ? ? ? ? </template>
? ? ? ? </el-table-column>
? ? ? </el-table>
? ? </div>js:
import { enums } from '@/utils/common'
data() {
? ? return {
? ? ? enums: enums
? ? }
? }以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
如何在Vue中使localStorage具有響應(yīng)式(思想實驗)
這篇文章主要介紹了如何在Vue中使localStorage具有響應(yīng)式,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
vue單頁應(yīng)用在頁面刷新時保留狀態(tài)數(shù)據(jù)的方法
今天小編就為大家分享一篇vue單頁應(yīng)用在頁面刷新時保留狀態(tài)數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vuejs 切換導(dǎo)航條高亮(路由菜單高亮)的方法示例
這篇文章主要介紹了vuejs 切換導(dǎo)航條高亮路由高亮的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05
Vue3.5中新增的baseWatch函數(shù)用法詳解
在Vue 3.5.0-beta.3版本中新增了一個base watch函數(shù),這個函數(shù)用法和我們熟知的watch API一模一樣,下面就跟隨小編一起來了解一下它的具體使用吧2024-11-11

