datagrivew删除列_vue iview 隐藏Table组件里的某一列操作

本文介绍了如何在Vue iView框架下动态控制Datagridview表格组件中的列显示和隐藏。通过判断条件决定是否显示特定列,并展示了如何监听多选框选择变化来实时更新列状态。同时,给出了使用v-for循环渲染el-table-column的示例,强调了数据对应关系的重要性。
摘要由CSDN通过智能技术生成

1、假设我要隐藏columns里的 “账户组名称”

columns: [

{

type: 'selection',

width: 60,

align: 'center'

},

{

title: '账号ID',

key: 'accountIdString'

},

{

title: '账号名称',

key: 'accountName'

},

{

title: '账户组名称',

key: 'accountGroupName'

}]

2、根据各自需求去判断

示例:如果是单账户表标题显示"账号ID、账号名称" 如果是账户组表标题显示"账户组名称"

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——动态控制表格列的显示和隐藏

如下所示:

907848651fdc3342cd0720310abd801f.png

如图,为要实现的需求,即右键table的表头弹出菜单栏,通过勾选多选框的内容来控制表格列的显示和隐藏。

1. HTML部分(elemen-ui):

(1) 通过v-if="colData[0].istrue",来判断表格列的状态

(2) @header-contextmenu是element-ui的table组件提供的事件,当表格表头被右键点击时触发该事件

2. Data部分:

data() {

return{

menuVisible: false, //右键菜单的显示与隐藏

top: 0, //右键菜单的位置

left: 0,

colOptions: ['放射源ID', '源自编号', '类型', '强度', '还源人'], //多选框的选择项

colSelect: ['放射源ID', '源自编号', '类型', '强度', '还源人'], //多选框已选择的内容,即表格中显示的列

// istrue属性存放列的状态

colData: [

{ title: '放射源ID', istrue: true },

{ title: '源自编号', istrue: true },

{ title: '类型', istrue: true },

{ title: '强度', istrue: true },

{ title: '还源人', istrue: true }

]

}

}

3. Js部分:

(1) 在watch部分监听选中项的变化

watch: {

colOptions(newVal, oldVal) {

if (newVal) { //如果有值发生变化,即多选框的已选项变化

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

}

})

}

}

},

(2)

methods: {

contextmenu(row, event) {

//先把菜单关闭,目的是第二次或者第n次右键鼠标的时候 它默认的是true

this.menuVisible = false

// 显示菜单

this.menuVisible = true

window.event.returnValue = false //阻止浏览器自带的右键菜单弹出

//给整个document绑定click监听事件, 左键单击任何位置执行foo方法

document.addEventListener('click', this.foo)

//event对应的是鼠标事件,找到鼠标点击位置的坐标,给菜单定位

this.top = event.clientY

this.left = event.clientX

},

foo() {

this.menuVisible = false //关闭菜单栏

document.removeEventListener('click', this.foo) //解绑click监听,很重要,具体原因可以看另外一篇博文

}

}

其中鼠标事件的返回值具体如下

1a80ac4aaa9df6e7856c7c740182b5e4.png

这里调用的clientX和clientY(鼠标点击位置相对于浏览器的坐标)来给菜单定位

4. CSS部分:

简单设置了一下菜单的样式,具体可以看情况修改

.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更新:

实际开发中一般表格列比较多的时候才会用到动态显隐。如果还是一条一条写el-table-column反而太过复杂,因此尝试了使用v-for来循环,亲测可用,具体代码如下~

border

:data="list"

highlight-current-row

@header-contextmenu="contextmenu"

>

v-for="(item,index) in tableHeader"

v-if="colData[index].istrue"

:key="item.key"

show-overflow-tooltip

:label="item.label"

:prop="item.key"

>

{{ scope.row.qyrq|parseTime() }}

{{ scope.row[item.key] }}

dara() {

return{

tableHeader: [

{ label: '放射源ID', key: 'id' },

{ label: '源自编号', key: 'zbh' },

{ label: '类型', key: 'kind' },

{ label: '强度', key: 'qd' },

{ label: '还源人', key: 'user' },

]

}}

需要注意的是,这里的tableHeader、colOptions、colSelect、colData中列的顺序需要一一对应不可错乱!

以上这篇vue iview 隐藏Table组件里的某一列操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

你可以通过以下步骤来删除 Vue + iView 表格中的某一行数据: 1. 在表格中添加一个“删除”列,并在该列中添加一个“删除”按钮,例如,可以使用如下代码: ```html <template> <Table :columns="columns" :data="tableData"> <template slot="operations" slot-scope="{row}"> <Button type="error" @click="deleteRow(row)">删除</Button> </template> </Table> </template> <script> export default { data() { return { columns: [ { title: '姓名', key: 'name' }, { title: '年龄', key: 'age' }, { title: '性别', key: 'gender' }, { title: '操作', slot: 'operations', align: 'center' }, ], tableData: [ { name: '张三', age: 18, gender: '男' }, { name: '李四', age: 20, gender: '女' }, { name: '王五', age: 22, gender: '男' }, ], }; }, methods: { deleteRow(row) { const index = this.tableData.indexOf(row); this.tableData.splice(index, 1); }, }, }; </script> ``` 在上面的代码中,我们在表格中添加了一个名为“operations”的插槽,该插槽对应了一个“删除”按钮,当用户点击该按钮时,会触发 `deleteRow()` 方法,该方法会从表格数据源中删除指定的行。 2. 最后,如果你想要删除某一行数据时,弹出一个确认框,让用户确认是否删除,可以使用 iView 的 `Modal` 对话框组件,例如,可以使用如下代码: ```html <template> <Table :columns="columns" :data="tableData"> <template slot="operations" slot-scope="{row}"> <Button type="error" @click="showDeleteConfirm(row)">删除</Button> </template> </Table> </template> <script> import { Modal } from 'iview'; export default { data() { return { columns: [ { title: '姓名', key: 'name' }, { title: '年龄', key: 'age' }, { title: '性别', key: 'gender' }, { title: '操作', slot: 'operations', align: 'center' }, ], tableData: [ { name: '张三', age: 18, gender: '男' }, { name: '李四', age: 20, gender: '女' }, { name: '王五', age: 22, gender: '男' }, ], }; }, methods: { showDeleteConfirm(row) { Modal.confirm({ title: '确认删除', content: `是否删除 ${row.name}?`, onOk: () => { const index = this.tableData.indexOf(row); this.tableData.splice(index, 1); }, }); }, }, }; </script> ``` 在上面的代码中,我们使用了 iView 的 `Modal` 对话框组件,当用户点击“删除”按钮时,会弹出一个确认框,让用户确认是否删除该行数据。如果用户点击“确定”按钮,则会从表格数据源中删除该行数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值