vue2+ant-design-vue a-descriptions 详情组件二次封装(vue2项目)


最终效果

图片[1] - vue2+ant-design-vue a-descriptions 详情组件二次封装(vue2项目) - MaxSSL

一、需求

一般后台管理系统,通常页面都有增删改查;而不外乎就是渲染新增/修改的数据(由输入框变成输入框禁用),因为输入框禁用后颜色透明度会降低,显的颜色偏暗;为解决这个需求于是封装了详情组件

二、源码

<template><div class="t_antd_detail"><a-descriptions size="middle" :column="descColumn" v-bind="$attrs"><a-descriptions-itemv-for="(item, key) in descData":key="key":label="item.label":span="item.span || 1"><template v-if="item.slotName"><slot :name="item.slotName" :scope="item"></slot></template><div v-else><a-tooltip v-bind="$attrs" v-if="item.tooltip"><span><spanv-if="item.filters&&item.filters.list">{{dataList[item.fieldName] |constantEscape(listTypeInfo[item.filters.list],(item.filters.key||'value'),(item.filters.label||'label'))}}</span><span v-else>{{ item.value }}</span><a-icon:type="item.iconClass||'exclamation-circle'":style="item.style||'cursor: pointer;'"/></span><template #title v-if="item.tooltip"><span v-if="typeof item.tooltip === 'string'">{{item.tooltip}}</span><template v-else-if="typeof item.tooltip === 'function'"><render-tooltip :createElementFunc="item.tooltip" /></template></template></a-tooltip><span v-else><spanv-if="item.filters&&item.filters.list">{{dataList[item.fieldName] |constantEscape(listTypeInfo[item.filters.list],(item.filters.key||'value'),(item.filters.label||'label'))}}</span><span v-else>{{ item.value }}</span></span></div></a-descriptions-item></a-descriptions></div></template><script>import { Descriptions, Tooltip, Icon } from 'ant-design-vue'import RenderTooltip from './renderTooltip.vue'import { constantEscape } from '../../utils'export default {name: 'TAntdDetail',components: {RenderTooltip,'a-icon': Icon,'a-tooltip': Tooltip,'a-descriptions': Descriptions,'a-descriptions-item': Descriptions.Item},// 过滤器filters: {constantEscape},props: {descColumn: {type: Number,default: 4},descData: {type: Array,default: () => ([])},// 后台数据源dataList: {type: Object,default: () => ({})},// 需要解析的下拉数据listTypeInfo: {type: Object,default: () => ({})}}}</script><style lang="scss">.t_antd_detail {.ant-descriptions {tr:nth-child(2n) {background-color: #fff;}.ant-descriptions-item-label {font-weight: bold;}}}</style>

三、参数配置

1、代码示例

<t-antd-detail :descData="descData" />

2、配置参数(Attributes)继承 a-descriptions Attributes

参数说明类型默认值
descData详情页面数据源Array
—-label详情字段说明标题String
—-value详情字段返回值String
—-fieldNamevalue 返回值的字段String
—-slotName插槽(自定义 value)slot
—-span占用的列宽,默认占用 1 列,最多 4 列Number1
—-tooltipvalue 值的提示语String/function
—-iconClasstooltip 提示语的 iconString‘exclamation-circle’
—-styletooltip 提示语的 icon的样式Object
—-filters字典类型(即后台返回的是数字类型)过滤转成中文Object
——-list字典 list 定义的数据名即 listTypeInfo 里面对应的值String
——-key下拉数据源的 key 字段String‘value’
——-label下拉数据源的 label 字段String‘label’
descColumn布局一行显示几列(默认:一行显示 4 列)Number4
dataList开启 filters 时详情接口返回的数据Object{}
listTypeInfo开启 filters 时下拉数据源Object{}

四、组件地址

gitHub组件地址

gitee码云组件地址

五、相关文章

基于ElementUi再次封装基础组件文档


基于ant-design-vue再次封装基础组件文档


vue3+ts基于Element-plus再次封装基础组件文档

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享