Vue后臺(tái)中優(yōu)雅書(shū)寫(xiě)狀態(tài)標(biāo)簽的方法實(shí)例
前言
在后臺(tái)系統(tǒng)開(kāi)發(fā)中,對(duì)于列表,常常有一些狀態(tài)字段的展示,比如審核狀態(tài)、退貨申請(qǐng)狀態(tài)等等,并且往往伴隨有狀態(tài)篩選的列表查詢(xún)條件,同時(shí)狀態(tài)顯示對(duì)應(yīng)不同顏色,在寫(xiě)代碼時(shí)有些人往往是這么做的:
<template>
<el-form :model="query">
<el-form-item label="審批狀態(tài)" prop="status">
<el-select v-model="query.status" clearable>
<el-option
v-for="item in statusOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary">查詢(xún)</el-button>
<el-button type="danger">重置</el-button>
</el-form-item>
</el-form>
<el-table :data="list">
<el-table-column label="審批狀態(tài)">
<template #default="{ row }">
<el-tag v-if="row.status === 0" type="primary">審核中</el-tag>
<el-tag v-if="row.status === 1" type="success">審核成功</el-tag>
<el-tag v-if="row.status === 2" type="danger">審核失敗</el-tag>
</template>
</el-table-column>
</el-table>
</template>
export default {
data() {
return {
query: {
status: null
},
statusOptions: [
{ label: '審核中', value: 0 },
{ label: '審核成功', value: 1 },
{ label: '審核失敗', value: 2 }
],
list: []
}
}
}
以上代碼雖然是實(shí)現(xiàn)了需求,但卻顯得不夠優(yōu)雅,代碼維護(hù)成本較高:
- 標(biāo)簽里充斥著較多的 v-if 且與 data 里的數(shù)據(jù)重復(fù),造成冗余。
- 當(dāng)有新增或修改時(shí),需要改動(dòng)多個(gè)地方,例如要改動(dòng)文案時(shí)下拉框和表格里的都要改。
- 如果是多個(gè)頁(yè)面都有該狀態(tài)需要顯示,復(fù)制粘貼,最后當(dāng)需求變動(dòng)時(shí)勢(shì)必會(huì)增加改動(dòng)成本。
優(yōu)化
針對(duì)上面的問(wèn)題,咱們通過(guò)以下措施來(lái)進(jìn)行搶救。
抽離變量
建立常量文件存放 statusOptions,增加 el-tag 組件的 type 字段來(lái)區(qū)分顯示不同的顏色,最后將其導(dǎo)出。
// const/index.js
// 審核狀態(tài)
const statusOptions = [
{ label: '審核中', value: 0, type: 'primary' },
{ label: '審核成功', value: 1, type: 'success' },
{ label: '審核失敗', value: 2, type: 'danger' }
]
export {
statusOptions
}
二次封裝 el-tag 組件
// components/stats-tag.vue
<template>
<el-tag :type="getValue('type')">
{{ getValue('label') }}
</el-tag>
</template>
export default {
name: 'StatusTag',
props: {
options: {
type: Array,
required: true,
default: () => []
},
status: {
type: [String, Number],
required: true
}
},
computed: {
getValue({ options, status }) {
return (key) => {
const item = options.find(e => e.value === status)
return (item && item[key]) || ''
}
}
}
}
使用
<template>
<el-form :model="query">
<el-form-item label="審批狀態(tài)" prop="status">
<el-select v-model="query.status" clearable>
<el-option
v-for="item in statusOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary">查詢(xún)</el-button>
<el-button type="danger">重置</el-button>
</el-form-item>
</el-form>
<el-table :data="list">
<el-table-column label="審批狀態(tài)">
<template #default="{ row }">
<!-- 使用 -->
<status-tag
:options="statusOptions"
:status="row.status"
/>
</template>
</el-table-column>
</el-table>
</template>
import StatusTag from '@/components/status-tag'
// 導(dǎo)入
import { statusOptions } from '@/const'
export default {
components: {
StatusTag
},
data() {
return {
statusOptions
}
}
}
經(jīng)過(guò)優(yōu)化后,如果有修改變動(dòng),只需要改動(dòng) const/index.js 文件即可,無(wú)需到處修。
// const/index.js
// 審核狀態(tài)
const statusOptions = [
{ label: '審核中', value: 0, type: 'primary' },
{ label: '審核成功', value: 1, type: 'success' },
{ label: '審核失敗', value: 2, type: 'danger' },
// 增加取消狀態(tài)
{ label: '審核取消', value: 3, type: 'warning' }
]
export {
statusOptions
}
總結(jié)
到此這篇關(guān)于Vue后臺(tái)中優(yōu)雅書(shū)寫(xiě)狀態(tài)標(biāo)簽的文章就介紹到這了,更多相關(guān)Vue書(shū)寫(xiě)狀態(tài)標(biāo)簽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
前端vue3中的ref與reactive用法及區(qū)別總結(jié)
這篇文章主要給大家介紹了關(guān)于前端vue3中的ref與reactive用法及區(qū)別的相關(guān)資料,關(guān)于ref及reactive的用法,還是要在開(kāi)發(fā)中多多使用,遇到響應(yīng)式失效問(wèn)題,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-08-08
Vue如何利用flex布局實(shí)現(xiàn)TV端城市列表功能
用vue開(kāi)發(fā)了三四個(gè)組件了,都是H5的,現(xiàn)在來(lái)看看PC是如何玩轉(zhuǎn)組件的,下面這篇文章主要給大家介紹了關(guān)于Vue如何利用flex布局實(shí)現(xiàn)TV端城市列表功能的相關(guān)資料,需要的朋友可以參考下2023-01-01
vue Element-ui input 遠(yuǎn)程搜索與修改建議顯示模版的示例代碼
本文分為html,js和css代碼給大家詳細(xì)介紹了vue Element-ui input 遠(yuǎn)程搜索與修改建議顯示模版功能,感興趣的朋友一起看看吧2017-10-10
vue實(shí)現(xiàn)上傳圖片添加水印(升級(jí)版)
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)上傳圖片添加水印的升級(jí)版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
五分鐘搞懂Vuex實(shí)用知識(shí)(小結(jié))
本篇文章主要介紹了五分鐘搞懂Vuex實(shí)用知識(shí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
Webpack+Vue如何導(dǎo)入Jquery和Jquery的第三方插件
本文主要介紹了Webpack+Vue導(dǎo)入Jquery和Jquery的第三方插件的方法,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02
vue兩個(gè)輸入框聯(lián)動(dòng)校驗(yàn)方式(最大值-最小值)
這篇文章主要介紹了vue兩個(gè)輸入框聯(lián)動(dòng)校驗(yàn)方式(最大值-最小值),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
Vue如何使用混合Mixins和插件開(kāi)發(fā)詳解
這篇文章主要介紹了Vue如何使用混合Mixins和插件開(kāi)發(fā)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02

