当前位置: 首页 > article >正文

vue3+elementplus表格表头加图标及文字提示

表头加自定义内容有很多种方法,包括使用el-icon,插槽,CSS 伪元素添加图标还有font-awesome等等。

一、方法一:使用render-header属性

<el-table :data="tableData"><el-table-column prop="name" label="姓名":render-header="(h, { column }) => {return (<div><span>{column.label}</span><el-tooltip content="这是姓名列提示" placement="top"><i class="el-icon-question" style="margin-left: 5px;"></i></el-tooltip></div>)}">

二、方法2:使用插槽

<el-table :data="tableData"><el-table-column prop="age" label="年龄"><template #header><div><span>年龄</span><el-tooltip content="这是年龄列提示" placement="top"><i class="el-icon-question" style="margin-left: 5px;"></i></el-tooltip></div></template></el-table-column>
</el-table>

三、方法3:通过 CSS 伪元素添加图标

<el-table :data="tableData"><el-table-column prop="address" label="地址" title="这是地址列提示"></el-table-column>
</el-table><style>
/* 在特定列后添加图标 */
.el-table__header th:nth-child(3) .cell::after {content: "\e609"; /* ElementPlus图标Unicode */font-family: "element-icons";margin-left: 5px;
}
</style>

四、方法4:封装自定义组件

<!-- components/TableHeader.vue -->
<template><div><span>{{ label }}</span><el-tooltip :content="tooltip" placement="top"><i class="el-icon-question" style="margin-left: 5px;"></i></el-tooltip></div>
</template><script>
export default {props: {label: String,tooltip: String}
}
</script><!-- 在表格中使用 -->
<el-table :data="tableData"><el-table-column prop="email" label="邮箱"><template #header><TableHeader label="邮箱" tooltip="这是邮箱列提示" /></template></el-table-column>
</el-table>

五、 Font Awesome 图标

1、使用 npm 或 yarn 安装核心库及所需图标集:
npm install @fortawesome/fontawesome-svg-core \@fortawesome/free-solid-svg-icons \@fortawesome/free-regular-svg-icons \@fortawesome/free-brands-svg-icons \@fortawesome/vue-fontawesome@prerelease
  • fontawesome-svg-core:核心库
  • free-solid-svg-icons:实心图标集
  • free-regular-svg-icons:常规图标集
  • free-brands-svg-icons:品牌图标集
  • vue-fontawesome@prerelease:Vue3 兼容版本
2、在 src/main.js 中导入并注册常用图标:
import { createApp } from 'vue'
import App from './App.vue'
import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome'
import { library } from '@fortawesome/fontawesome-svg-core'// 导入需要的图标
import { faUser, faEnvelope, faPhone, faInfoCircle,faEdit, faTrash, faCheck, faTimes 
} from '@fortawesome/free-solid-svg-icons'// 将图标添加到库中
library.add(faUser, faEnvelope, faPhone, faInfoCircle, faEdit, faTrash, faCheck, faTimes)createApp(App).component('font-awesome-icon', FontAwesomeIcon) // 全局注册组件.mount('#app')
3、在 Vue 模板中直接使用 <font-awesome-icon> 组件
<template><div><!-- 基本用法 --><font-awesome-icon icon="user" /><!-- 带样式的图标 --><font-awesome-icon icon="envelope" class="text-blue-500 text-xl" /><!-- 品牌图标 --><font-awesome-icon icon="['fab', 'github']" /><!-- 动态图标 --><font-awesome-icon :icon="currentIcon" /></div>
</template><script>
export default {data() {return {currentIcon: 'check' // 动态切换图标}}
}
</script>
4、在特定组件中使用图标
<template><div><font-awesome-icon :icon="faUser" /></div>
</template><script>
import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome'
import { faUser } from '@fortawesome/free-solid-svg-icons'export default {components: {FontAwesomeIcon},setup() {return {faUser}}
}
</script>

总结:

我用到的实在特定页面特定表格列使用图标,主要代码:

html:

<el-table-columnv-else-if="!item.show":prop="item.prop":label="item.name"header-align="center":width="item.width"align="center":render-header="(props) => renderHeaderWithTooltip(props, item)"> <template #default="scope"><div v-if="item.name=='教育教学信息状态'"><text v-if="scope.row[item.prop] == 0">已填写</text><text v-else style="color: red">{{ scope.row[item.prop] }}项未填写</text></div><div v-else><text v-if="scope.row[item.prop] == 0">完善</text><text v-else-if="item.separate" style="color: red">未完善</text><text v-else style="color: red">{{ scope.row[item.prop] }}项未完善 </text></div></template></el-table-column>

js:

//引入
import { h } from 'vue';
import { ElTooltip } from 'element-plus';
import 'font-awesome/css/font-awesome.min.css';/ 表头展示图标及提示
const renderHeaderWithTooltip = (props, item) => {const tooltipContent = {'编制信息状态': '该教师除"隶属集团"外的字段未填写的数量','教育教学信息状态': '近5年教育教学填写情况','个人信息状态': '该教师除"曾用名"外的字段未填写的数量'}[item.name];if (tooltipContent) {return h(ElTooltip,{ placement: 'top', content: tooltipContent },{default: () => h('div',{ class: 'flex items-center justify-center' },[h('i', {class: 'fa fa-info-circle mr-3 text-primary',style:{'font-size': '16px','margin-top': '3px'} }),h('span', props.column.label)])});} else {// 对于不需要提示的列,直接显示标签return h('span', props.column.label);}
};

http://www.lryc.cn/news/2401792.html

相关文章:

  • 【物联网-S7Comm协议】
  • NLP中的input_ids是什么?
  • LeetCode Hot100刷题——划分字母区间
  • c++ 基于OpenSSL的EVP接口进行SHA3-512和SM3哈希计算
  • Vue3实现拖拽改变元素大小
  • Spring IoC 详解:原理、实现与实战
  • 深入Java NIO:构建高性能网络应用
  • 数据分析后台设计指南:实战案例解析与5大设计要点总结
  • 深度学习之模型压缩三驾马车:基于ResNet18的模型剪枝实战(1)
  • SSH/RDP无法远程连接?腾讯云CVM及通用服务器连接失败原因与超全排查指南
  • 网络测试实战:金融数据传输的生死时速
  • 数据库系统概论(十四)详细讲解SQL中空值的处理
  • 【信创-k8s】海光/兆芯+银河麒麟V10离线部署k8s1.31.8+kubesphere4.1.3
  • [蓝桥杯]三体攻击
  • 深入解析支撑向量机(SVM):原理、推导与实现
  • 一台电脑联网如何共享另一台电脑?网线方式
  • 面试题:SQL 中如何将 多行合并为一行(合并行数据为列)?
  • MacroDroid安卓版:自动化操作,让生活更智能
  • 力提示(force prompting)的新方法
  • 【Redis实战:缓存与消息队列的应用】
  • 实验设计与分析(第6版,Montgomery著,傅珏生译) 第10章拟合回归模型10.9节思考题10.12 R语言解题
  • 基于LangChain构建高效RAG问答系统:向量检索与LLM集成实战
  • 告别局域网:实现NASCab云可云远程自由访问
  • 25_05_29docker
  • Java-IO流之缓冲流详解
  • vscode code runner 使用python虚拟环境
  • Python实现markdown文件转word
  • NLP学习路线图(十七):主题模型(LDA)
  • 深度学习之模型压缩三驾马车:基于ResNet18的模型剪枝实战(2)
  • 综采工作面电控4X型铜头连接器 conm/4x100s