詳解el-table表頭文字換行的三種方式
問題描述
表格中的表頭一般都是不換行的,不過有時候在某些業(yè)務場景中,需要讓表頭的文字換行展示一下,我們先看一下效果圖
效果圖

三種方式的代碼
看注釋就行啦。
演示的話,直接復制粘貼運行就行啦
<template>
<div class="vueWrap">
<el-table
style="width: 900px"
:data="tableBody"
border
:header-cell-style="{
background: '#FAFAFA',
color: '#333333',
fontWeight: 'bold',
fontSize: '14px',
}"
>
<el-table-column
type="index"
label="序號"
width="58"
align="center"
></el-table-column>
<!-- 表頭換行方式一,使用頭部插槽方式,將表頭文字拆分在兩個div中,因為div盒子是塊元素
所以兩個div會換行,所以表頭就換行了,此方式適用于固定數(shù)據(jù)的表頭換行 -->
<el-table-column prop="toolName" width="180" align="center">
<template slot="header">
<div>工具箱</div>
<div>零件名稱</div>
</template>
<template slot-scope="scope">
<span>{{ scope.row.toolName }}</span>
</template>
</el-table-column>
<el-table-column label="供應商" prop="supplier" width="120" align="center">
</el-table-column>
<!-- 表頭換行方式二,較之于方式一,這種方式是/n換行符,加css的white-space空白樣式控制-->
<el-table-column
:label="labelFn()"
prop="supplierCountry"
width="180"
align="center"
>
</el-table-column>
<!-- 表頭換行方式三,動態(tài)方式 -->
<el-table-column
v-for="(item, index) in tableHeader"
:key="index"
:label="item.labelName"
:prop="item.propName"
width="180"
align="center"
:render-header="renderheader"
></el-table-column>
</el-table>
</div>
</template>
<script>
export default {
data() {
return {
// 動態(tài)數(shù)據(jù)表頭就需要讓后端返回來了,讓其在需要換行的地方用逗號分隔開
tableHeader: [
{
labelName: "型號001,價格(元)",
propName: "typeOne",
},
{
labelName: "型號002,價格(元)",
propName: "typeTwo",
},
],
// 表體數(shù)據(jù)
tableBody: [
{
id: "2021111101",
toolName: "5G服務",
supplier: "華為",
supplierCountry: "中國",
typeOne: "8888888",
typeTwo: "9999999",
},
{
id: "2021111101",
toolName: "6G-SERVER",
supplier: "中華有為",
supplierCountry: "CHINA",
typeOne: "678678678",
typeTwo: "789789789",
},
],
};
},
methods: {
labelFn() {
// 在需要換行的地方加入換行符 \n ,在搭配最底下的white-space樣式設置
return `供應商\n所屬國家`;
},
// 餓了么UI的表頭函數(shù)渲染方式,這種方式和表頭插槽方式有點類似
// 也是把表頭的數(shù)據(jù)文字分割成兩塊,然后將內容渲染到兩個div中(div自動換行)
renderheader(h, { column, $index }) {
return h("div", {}, [
h("div", {}, column.label.split(",")[0]),
h("div", {}, column.label.split(",")[1]),
]);
},
},
};
</script>
<style lang="less" scoped>
/deep/ .el-table th.el-table__cell > .cell {
white-space: pre;
// white-space: pre-wrap; // 也行。
}
</style>
關于white-space不贅述,詳情查詢官方文檔 developer.mozilla.org/zh-CN/docs/Web/CSS/white-space
總結
三種方式各有特色,但是render-header會略為耗費一點點性能。
若為固定表頭數(shù)據(jù),則優(yōu)先推薦使用表頭插槽方式,其次推薦換行符加css方式。
若為動態(tài)數(shù)據(jù),則只能使用表頭renderheader函數(shù)了
到此這篇關于el-table表頭文字換行的三種方式的文章就介紹到這了,更多相關el-table表頭文字換行的三種方式內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue中el-form-item展開項居中的實現(xiàn)方式
這篇文章主要介紹了vue中el-form-item展開項居中的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
Vue?通過this.$emit()方法子組件向父組件傳值(步驟分享)
這篇文章主要介紹了Vue?this.$emit()方法通過子組件向父組件傳值,第一步在父組件中引入子組件,第二步子組件向父組件傳值,本文通過需要的朋友可以參考下2022-11-11
Vue3后臺管理系統(tǒng)之創(chuàng)建和配置項目
后臺管理系統(tǒng)是我們日常開發(fā)學習經常遇到的一個項目,下面這篇文章主要給大家介紹了關于Vue3后臺管理系統(tǒng)之創(chuàng)建和配置項目的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-09-09

