欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue iview 隱藏Table組件里的某一列操作

 更新時(shí)間:2020年11月13日 09:55:54   作者:Yilia-Feng  
這篇文章主要介紹了vue iview 隱藏Table組件里的某一列操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

1、假設(shè)我要隱藏columns里的 “賬戶組名稱”

columns: [
{
 type: 'selection',
 width: 60,
 align: 'center'
},
{
 title: '賬號(hào)ID',
 key: 'accountIdString'
},
{
 title: '賬號(hào)名稱',
 key: 'accountName'
},
{
 title: '賬戶組名稱',
 key: 'accountGroupName'
}]

2、根據(jù)各自需求去判斷

示例:如果是單賬戶表標(biāo)題顯示"賬號(hào)ID、賬號(hào)名稱" 如果是賬戶組表標(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' );
 }

補(bǔ)充知識(shí):vue——?jiǎng)討B(tài)控制表格列的顯示和隱藏

如下所示:

如圖,為要實(shí)現(xiàn)的需求,即右鍵table的表頭彈出菜單欄,通過(guò)勾選多選框的內(nèi)容來(lá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="源自編號(hào)" align="center" />
 <el-table-column v-if="colData[2].istrue" label="類型" align="center" />
 <el-table-column v-if="colData[3].istrue" label="強(qiáng)度" align="center" />
 <el-table-column v-if="colData[4].istrue" label="還源人" align="center" />
</el-table>
<!--右鍵彈出的菜單內(nèi)容-->
<!--動(dòng)態(tài)計(jì)算菜單出現(xiàn)的位置-->
<div v-show="menuVisible" :style="{top:top+ &quot;px&quot;,left:left+ &quot;px&quot;}" class="menu1">
 <el-checkbox-group v-model="colOptions">
 <el-checkbox v-for="item in colSelect" :key="item" :label="item" />
 </el-checkbox-group>
</div>

(1) 通過(guò)v-if="colData[0].istrue",來(lái)判斷表格列的狀態(tài)

(2) @header-contextmenu是element-ui的table組件提供的事件,當(dāng)表格表頭被右鍵點(diǎn)擊時(shí)觸發(fā)該事件

2. Data部分:

data() {
 return{
 menuVisible: false, //右鍵菜單的顯示與隱藏
 top: 0, //右鍵菜單的位置
 left: 0,
 colOptions: ['放射源ID', '源自編號(hào)', '類型', '強(qiáng)度', '還源人'], //多選框的選擇項(xiàng)
 colSelect: ['放射源ID', '源自編號(hào)', '類型', '強(qiáng)度', '還源人'], //多選框已選擇的內(nèi)容,即表格中顯示的列
 // istrue屬性存放列的狀態(tài)
 colData: [
 { title: '放射源ID', istrue: true },
 { title: '源自編號(hào)', istrue: true },
 { title: '類型', istrue: true },
 { title: '強(qiáng)度', istrue: true },
 { title: '還源人', istrue: true }
 ]
 }
}

3. Js部分:

(1) 在watch部分監(jiān)聽(tīng)選中項(xiàng)的變化

<script>
watch: {
 colOptions(newVal, oldVal) {
 if (newVal) { //如果有值發(fā)生變化,即多選框的已選項(xiàng)變化
 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)的時(shí)候 它默認(rèn)的是true
 this.menuVisible = false 
 // 顯示菜單
 this.menuVisible = true 
 window.event.returnValue = false //阻止瀏覽器自帶的右鍵菜單彈出
 //給整個(gè)document綁定click監(jiān)聽(tīng)事件, 左鍵單擊任何位置執(zhí)行foo方法
 document.addEventListener('click', this.foo) 
 //event對(duì)應(yīng)的是鼠標(biāo)事件,找到鼠標(biāo)點(diǎn)擊位置的坐標(biāo),給菜單定位
 this.top = event.clientY
 this.left = event.clientX
 },
 foo() {
 this.menuVisible = false //關(guān)閉菜單欄
 document.removeEventListener('click', this.foo) //解綁click監(jiān)聽(tīng),很重要,具體原因可以看另外一篇博文
 }
 }

其中鼠標(biāo)事件的返回值具體如下

這里調(diào)用的clientX和clientY(鼠標(biāo)點(diǎn)擊位置相對(duì)于瀏覽器的坐標(biāo))來(lái)給菜單定位

4. CSS部分:

簡(jiǎn)單設(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更新:

實(shí)際開(kāi)發(fā)中一般表格列比較多的時(shí)候才會(huì)用到動(dòng)態(tài)顯隱。如果還是一條一條寫el-table-column反而太過(guò)復(fù)雜,因此嘗試了使用v-for來(lái)循環(huán),親測(cè)可用,具體代碼如下~

<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: '源自編號(hào)', key: 'zbh' },
  { label: '類型', key: 'kind' },
  { label: '強(qiáng)度', key: 'qd' },
  { label: '還源人', key: 'user' },
 ]
 }}

需要注意的是,這里的tableHeader、colOptions、colSelect、colData中列的順序需要一一對(duì)應(yīng)不可錯(cuò)亂!

以上這篇vue iview 隱藏Table組件里的某一列操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue.js中el-table表格自定義列控制與拖拽

    Vue.js中el-table表格自定義列控制與拖拽

    本文主要介紹了Vue.js中el-table表格自定義列控制與拖拽,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • vue基于兩個(gè)計(jì)算屬性實(shí)現(xiàn)選中和全選功能示例

    vue基于兩個(gè)計(jì)算屬性實(shí)現(xiàn)選中和全選功能示例

    這篇文章主要介紹了vue基于兩個(gè)計(jì)算屬性實(shí)現(xiàn)選中和全選功能,結(jié)合實(shí)例形式分析了vue計(jì)算屬性get及set操作頁(yè)面元素實(shí)現(xiàn)選中與全選功能相關(guān)操作技巧,需要的朋友可以參考下
    2019-02-02
  • Vue插件從封裝到發(fā)布的完整步驟記錄

    Vue插件從封裝到發(fā)布的完整步驟記錄

    這篇文章主要給大家介紹了關(guān)于Vue插件從封裝到發(fā)布的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • 沒(méi)有搭建腳手架時(shí)vue組件的使用方式

    沒(méi)有搭建腳手架時(shí)vue組件的使用方式

    這篇文章主要介紹了沒(méi)有搭建腳手架時(shí)vue組件的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue項(xiàng)目引入antDesignUI組件實(shí)現(xiàn)

    vue項(xiàng)目引入antDesignUI組件實(shí)現(xiàn)

    本文介紹了如何以Vue引入antDesignUI,主要包括下載安裝、配置和引入組件等步驟,通過(guò)本文,讀者可以快速了解antDesignUI在Vue中的應(yīng)用,感興趣的可以了解一下
    2023-08-08
  • vue實(shí)現(xiàn)a標(biāo)簽點(diǎn)擊高亮方法

    vue實(shí)現(xiàn)a標(biāo)簽點(diǎn)擊高亮方法

    下面小編就為大家分享一篇vue實(shí)現(xiàn)a標(biāo)簽點(diǎn)擊高亮方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • 傻瓜式vuex語(yǔ)法糖kiss-vuex整理

    傻瓜式vuex語(yǔ)法糖kiss-vuex整理

    kiss-vuex 是一個(gè)非常簡(jiǎn)單的語(yǔ)法糖類庫(kù),這篇文章主要介紹了傻瓜式vuex語(yǔ)法糖kiss-vuex整理,非常具有實(shí)用價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • ElementUI?$notify通知方法中渲染自定義組件實(shí)現(xiàn)

    ElementUI?$notify通知方法中渲染自定義組件實(shí)現(xiàn)

    這篇文章主要為大家介紹了ElementUI?$notify通知方法中渲染自定義組件實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • 詳解Vue-cli代理解決跨域問(wèn)題

    詳解Vue-cli代理解決跨域問(wèn)題

    本篇文章主要介紹了Vue-cli代理解決跨域問(wèn)題,詳細(xì)的介紹了Vue如何設(shè)置代理,具有一定參考價(jià)值,有興趣的可以了解一下
    2017-09-09
  • vue 自定義全局方法,在組件里面的使用介紹

    vue 自定義全局方法,在組件里面的使用介紹

    下面小編就為大家介紹一下vue 自定義全局方法,在組件里面的使用。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02

最新評(píng)論