vue iview 隱藏Table組件里的某一列操作
1、假設(shè)我要隱藏columns里的 “賬戶組名稱”
columns: [
{
type: 'selection',
width: 60,
align: 'center'
},
{
title: '賬號ID',
key: 'accountIdString'
},
{
title: '賬號名稱',
key: 'accountName'
},
{
title: '賬戶組名稱',
key: 'accountGroupName'
}]
2、根據(jù)各自需求去判斷
示例:如果是單賬戶表標(biāo)題顯示"賬號ID、賬號名稱" 如果是賬戶組表標(biāo)題顯示"賬戶組名稱"
if(this.queryCostComparisonData[i].accountGroupName){
this.columns = this.columns.filter(col => col.key !== 'accountIdString' );
this.columns = this.columns.filter(col => col.key !== 'accountName' );
}else{
this.columns = this.columns.filter(col => col.key !== 'accountGroupName' );
}
補充知識:vue——動態(tài)控制表格列的顯示和隱藏
如下所示:

如圖,為要實現(xiàn)的需求,即右鍵table的表頭彈出菜單欄,通過勾選多選框的內(nèi)容來控制表格列的顯示和隱藏。
1. HTML部分(elemen-ui):
<el-table :data="list" border fit @header-contextmenu="contextmenu">
<el-table-column v-if="colData[0].istrue" label="放射源ID" align="center" />
<el-table-column v-if="colData[1].istrue" label="源自編號" align="center" />
<el-table-column v-if="colData[2].istrue" label="類型" align="center" />
<el-table-column v-if="colData[3].istrue" label="強度" align="center" />
<el-table-column v-if="colData[4].istrue" label="還源人" align="center" />
</el-table>
<!--右鍵彈出的菜單內(nèi)容-->
<!--動態(tài)計算菜單出現(xiàn)的位置-->
<div v-show="menuVisible" :style="{top:top+ "px",left:left+ "px"}" class="menu1">
<el-checkbox-group v-model="colOptions">
<el-checkbox v-for="item in colSelect" :key="item" :label="item" />
</el-checkbox-group>
</div>
(1) 通過v-if="colData[0].istrue",來判斷表格列的狀態(tài)
(2) @header-contextmenu是element-ui的table組件提供的事件,當(dāng)表格表頭被右鍵點擊時觸發(fā)該事件
2. Data部分:
data() {
return{
menuVisible: false, //右鍵菜單的顯示與隱藏
top: 0, //右鍵菜單的位置
left: 0,
colOptions: ['放射源ID', '源自編號', '類型', '強度', '還源人'], //多選框的選擇項
colSelect: ['放射源ID', '源自編號', '類型', '強度', '還源人'], //多選框已選擇的內(nèi)容,即表格中顯示的列
// istrue屬性存放列的狀態(tài)
colData: [
{ title: '放射源ID', istrue: true },
{ title: '源自編號', istrue: true },
{ title: '類型', istrue: true },
{ title: '強度', istrue: true },
{ title: '還源人', istrue: true }
]
}
}
3. Js部分:
(1) 在watch部分監(jiān)聽選中項的變化
<script>
watch: {
colOptions(newVal, oldVal) {
if (newVal) { //如果有值發(fā)生變化,即多選框的已選項變化
var arr = this.colSelect.filter(i => newVal.indexOf(i) < 0) // 未選中
this.colData.filter(i => {
if (arr.indexOf(i.title) !== -1) {
i.istrue = false
} else {
i.istrue = true
}
})
}
}
},
</script>
(2)
methods: {
contextmenu(row, event) {
//先把菜單關(guān)閉,目的是第二次或者第n次右鍵鼠標(biāo)的時候 它默認(rèn)的是true
this.menuVisible = false
// 顯示菜單
this.menuVisible = true
window.event.returnValue = false //阻止瀏覽器自帶的右鍵菜單彈出
//給整個document綁定click監(jiān)聽事件, 左鍵單擊任何位置執(zhí)行foo方法
document.addEventListener('click', this.foo)
//event對應(yīng)的是鼠標(biāo)事件,找到鼠標(biāo)點擊位置的坐標(biāo),給菜單定位
this.top = event.clientY
this.left = event.clientX
},
foo() {
this.menuVisible = false //關(guān)閉菜單欄
document.removeEventListener('click', this.foo) //解綁click監(jiān)聽,很重要,具體原因可以看另外一篇博文
}
}
其中鼠標(biāo)事件的返回值具體如下

這里調(diào)用的clientX和clientY(鼠標(biāo)點擊位置相對于瀏覽器的坐標(biāo))來給菜單定位
4. CSS部分:
簡單設(shè)置了一下菜單的樣式,具體可以看情況修改
.menu1{
position:fixed;
height:auto;
width:231px;
border-radius: 3px;
border: 1px solid #999999;
background-color: #f4f4f4;
padding: 10px;
z-index: 1000
}
.el-checkbox{
display:block;
height:20px;
line-height:20px;
padding:0 5px;
margin-right:0;
font-size:12px;
border: 1px solid transparent;
}
.el-checkbox:hover{
border-radius: 3px;
border: 1px solid #999999;
}
2019-9-25更新:
實際開發(fā)中一般表格列比較多的時候才會用到動態(tài)顯隱。如果還是一條一條寫el-table-column反而太過復(fù)雜,因此嘗試了使用v-for來循環(huán),親測可用,具體代碼如下~
<el-table
border
:data="list"
highlight-current-row
@header-contextmenu="contextmenu"
>
<el-table-column
v-for="(item,index) in tableHeader"
v-if="colData[index].istrue"
:key="item.key"
show-overflow-tooltip
:label="item.label"
:prop="item.key"
>
<template slot-scope="scope">
<span v-if="(item.key==='qyrq'||item.key==='ccrq'||item.key==='zcsj')&&scope.row[item.key]">{{ scope.row.qyrq|parseTime() }}</span>
<span v-else>{{ scope.row[item.key] }} </span>
</template>
</el-table-column>
</el-table>
dara() {
return{
tableHeader: [
{ label: '放射源ID', key: 'id' },
{ label: '源自編號', key: 'zbh' },
{ label: '類型', key: 'kind' },
{ label: '強度', key: 'qd' },
{ label: '還源人', key: 'user' },
]
}}
需要注意的是,這里的tableHeader、colOptions、colSelect、colData中列的順序需要一一對應(yīng)不可錯亂!
以上這篇vue iview 隱藏Table組件里的某一列操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- vue3應(yīng)用elementPlus table并滾動顯示問題
- vue3?el-table結(jié)合seamless-scroll實現(xiàn)表格數(shù)據(jù)滾動的思路詳解
- vue中el-table兩個表尾合計行聯(lián)動同步滾動條實例代碼
- vue中獲取滾動table的可視頁面寬度調(diào)整表頭與列對齊(每列寬度不都相同)
- vue elementUI table表格數(shù)據(jù) 滾動懶加載的實現(xiàn)方法
- vue element-ui table表格滾動加載方法
- Vue基于iview table展示圖片實現(xiàn)點擊放大
- 淺談vue的iview列表table render函數(shù)設(shè)置DOM屬性值的方法
- vue 使用iView組件中的Table實現(xiàn)定時自動滾動效果
相關(guān)文章
vue3集成Element-plus實現(xiàn)按需自動引入組件的方法總結(jié)
vue3出來一段時間了,element也更新了版本去兼容vue3,下面這篇文章主要給大家介紹了關(guān)于vue3集成Element-plus實現(xiàn)按需自動引入組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
Vue3實現(xiàn)跨頁面?zhèn)髦档膸追N常見方法
在Vue 3中,跨頁面?zhèn)髦悼梢酝ㄟ^多種方式實現(xiàn),具體選擇哪種方法取決于應(yīng)用的具體需求和頁面間的關(guān)系,本文列舉了幾種常見的跨頁面?zhèn)髦捣椒?感興趣的同學(xué)跟著小編來看看吧2024-04-04
vue預(yù)覽本地pdf文件方法之vue-pdf組件使用
這篇文章主要介紹了vue預(yù)覽本地pdf文件方法之vue-pdf組件使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
深入探討如何在Vue中使用EventBus實現(xiàn)組件間的高效通信
在現(xiàn)代前端開發(fā)中,Vue.js?作為一種流行的漸進式框架,廣泛應(yīng)用于各類?Web?項目的構(gòu)建中,本文將深入探討如何在?Vue?中使用?EventBus,實現(xiàn)組件間的高效通信,需要的可以了解下2024-11-11
基于ant-design-vue實現(xiàn)表格操作按鈕組件
這篇文章主要為大家介紹了基于ant-design-vue實現(xiàn)表格操作按鈕組件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06

