ElementUI的el-table表头的全选事件与自动清空事件
2018-07-11 09:40
3651 查看
版权声明:本文为博主原创文章,未经博主允许不得转载 https://blog.csdn.net/java_xxxx/article/details/80995386
最近用到elementUI的table的单选和全选事件,其中elementUI的表头的全选事件的选中与取消,做下笔记。
官方文档如下:
我们可以设置下面这个方法,然后,在方法中处理被选中的事件。
select-all 当用户手动勾选全选 Checkbox 时触发的事件 selection
批量选者就不说了,大家可以看我其他的文章,有一章专门说批量的。
废话不多说,直接上代码
html:
<el-row class="yt-row"> <el-col :span="24"> <el-table height="460" :data="submitList" @select="selectionChange" v-model="check2" style="width: 100%" :stripe="true" ref="articleTable" border="false" @select-all="selectAll" @clearSelection="clearSelect" > <el-table-column type="selection" width="50"></el-table-column> <el-table-column prop="" label="类型" width="60" align="center"> <template scope="scope"> <img src="../../images/article_normal.png" title="文章"> </template> </el-table-column>
全选事件:当用户手动勾选全选 Checkbox 时触发的事件:@select-all
大致思路,当点击全选的时候,我定义了一个集合,专门存放选中事件的数据的id,我将选中的id放入这个集合里,如果该id在集合中不存在,就添加,如果存在就移除。因为每次点击(单击或者是全选)都会触发,只要点击checbox就会触发。例如,第二行未选中状态,这次你点击了第二行,那就将第二行id添加,当你再次点击第二行的时候,那就是取消了,于是若该集合中有id,就移除。
js代码:
// 全选 selectAll:function () { if(app.selectedIds.length != app.pagination.total){ for(var i in app.submitList){ if(app.selectedIds.indexOf(app.submitList[i].id)==-1){ app.selectedIds.push(app.submitList[i].id); } } }else{ app.selectedIds.splice(0,app.pagination.total); } }
这里的this.$refs.articleTable.clearSelection();方法articleTable为table引用的名字。即table里的ref=“articleTable”。这里的清空逻辑,就是我点击全选的时候,所有都为选中状态,然后我点击导出数据,将数据导出,导出后,它会自动将所有选中都清空。
js
toggleSelection:function(rows) { // 这里的articleTable为表格引用的名字。 // 个人理解:如果这行代码直接写在回调函数里,那么这个this就是相当于回调函数来说的,就会报未定义的异常 this.$refs.articleTable.clearSelection(); var len = app.selectedIds.length; app.selectedIds=splice(0,len); // 移除选中的数据 },阅读更多
相关文章推荐
- elementUI的el-tree节点过滤事件
- 关于jquery实现table列表的全选框事件的总结
- el-table多表头-动态列-在后台管理系统权限分配中的实现
- HTML angular购物车:加减按钮改变数量+全选+低于1时提示删除商品+计算所有商品总价+清空购物车+单独删除+输入内容小于1时,自动变为1+反选
- Chrome、Safari下焦点事件中的select()自动全选
- 浅析响应式框架中,table表头自动换行的快速解决方法
- 一个简单的js事件,循环table并自动计算总价
- HTML angular购物车:加减按钮改变数量+全选+低于1时提示删除商品+计算所有商品总价+清空购物车+单独删除+输入内容小于1时,自动变为1+反选
- 使用tableview的表头button 实现多 cell 的选择
- table 固定表头、列头
- 如何让TreeView的TreeNodeCheckChanged事件自动回发到服务器端
- bootstrap固定table表头
- Jquery自动执行事件
- Saiku如何固定查询结果table的表头和首列
- 如何让TreeView的TreeNodeCheckChanged事件自动回发到服务器端
- table中表格内的内容自动换行不改变表格宽度
- HTML或者JSP页面--执行完某事件后刷新页面,重置表单,清空数据
- 手动重置事件和自动重置事件
- QSqlTableMode设置单张表的查询过滤条件与表中有一列 id自动增加
- 滚动条事件,当页面滚动到距顶部一定高度时某DIV自动隐藏和显示