首页 > 其他分享 >element表格多选改为单选,且去除表头的多选框

element表格多选改为单选,且去除表头的多选框

时间:2023-06-25 14:00:18浏览次数:47  
标签:val refs 表头 element 单选 multipleTable table multipleSelection row

一、利用el-table自带方法selection-change(当选择项发生变化时触发该事件)
关键代码:
this.$refs.serialnoTable.clearSelection() this.$refs.serialnoTable.toggleRowSelection(val.pop()) 

1.@selection-change="handleSelectionChange" 是重点改变点击选择框后的事件:

<el-table   ref="multipleTable"   :data="persionTable"   tooltip-effect="dark"   style="width: 100%"   @selection-change="handleSelectionChange" >   <el-table-column type="selection" width="55"> </el-table-column>   <el-table-column prop="name" label="姓名" width="120"> </el-table-column>   <el-table-column prop="address" label="职称" show-overflow-tooltip>   </el-table-column> </el-table> 2.ref="multipleTable" 是必须的,后面会用到这个的实例方法clear 用来清空所有勾选项 

利用判断来判断如果超过一个勾选框就先清空最后把当前最新勾选的那一项放入用来储存勾选容器this.multipleSelectionUpdate内

注意点: 需要注意不实时更新的bug: this.$set(this.multipleSelectionUpdate, val[0]);

// 勾选框
handleSelectionChange(val) {
// this.multipleSelection = val;
if (val.length > 1) {
this.$refs.multipleTable.clearSelection();
this.$refs.multipleTable.toggleRowSelection(val.pop());
} else {
this.multipleSelectionUpdate = val;
}
// this.multipleSelectionUpdate = val[0];// 这种赋值同样不会实时更新
this.$set(this.multipleSelectionUpdate, val[0]);
console.log(this.multipleSelectionUpdate, this.multipleSelection); // 此时要回显到页面的值
},

3.如果简化写法,简单用,这样写也同样可以快速单选切换:

handleSelectionChange(val) {
this.multipleSelection = val;
if (val.length > 1) {
this.$refs.multipleTable.clearSelection();
this.$refs.multipleTable.toggleRowSelection(val.pop());
}
},

 

二、

1.将element中的 table 表格 组件中的 多选 代码,拷贝到自己的前端项目中:

<el-table ref="multipleTable" :data="tableData" tooltip-effect="dark" style="width: 100%" >
  <el-table-column type="selection" width="55"></el-table-column>
  <el-table-column label="日期" width="120">
    <template slot-scope="scope">{{ scope.row.date }}</template>
  </el-table-column>
  <el-table-column prop="name" label="姓名" width="120"></el-table-column>
  <el-table-column prop="address" label="地址" show-overflow-tooltip></el-table-column>
</el-table> 

2.去除 表头出行 多选的勾选框,在 el-table 的标签中 加上样式 class = "table-style",从样式上隐藏 该全选的勾选框, 代码如下

<el-table class="table-style" ref="multipleTable" :data="tableData" tooltip-effect="dark"  style="width: 100%" >   <el-table-column type="selection" width="55"> </el-table-column>   <el-table-column label="日期" width="120">     <template slot-scope="scope">{{ scope.row.date }}</template>   </el-table-column>   <el-table-column prop="name" label="姓名" width="120"> </el-table-column>   <el-table-column prop="address" label="地址" show-overflow-tooltip>   </el-table-column> </el-table> <-- 从样式上 隐藏 全选勾选框 --> <style lang="less">   .table-style {     .el-table-column--selection.is-leaf .el-checkbox {       display: none;     }   } </style> 3.将多选改为 单选 功能,在el-table 的标签中重新定义 一个方法 @select="selectInfo" ,用于将单选功能实现, 代码如下: <el-table  class= "table-style" ref="multipleTable" :data="tableData" tooltip-effect="dark" style="width: 100%" @select="selectInfo">   <el-table-column type="selection" width="55"> </el-table-column>   <el-table-column label="日期" width="120">     <template slot-scope="scope">{{ scope.row.date }}</template>   </el-table-column>   <el-table-column prop="name" label="姓名"  width="120"></el-table-column>   <el-table-column prop="address" label="地址" show-overflow-tooltip></el-table-column>  </el-table> <script>   data() {      return {        multipleTable: "", //所选择的表格数据指向      };    },   methods: {         selectInfo(selection, row) {            console.log(selection, row);            // 清除 所有勾选项            this.$refs.multipleTable.clearSelection();            // 当表格数据都没有被勾选的时候 就返回            // 主要用于将当前勾选的表格状态清除            if (selection.length == 0) return;            this.$refs.multipleTable.toggleRowSelection(row, true);          },           } </script> <-- 从样式上 隐藏 全选勾选框 -->      <style lang="less">          .table-style {            .el-table-column--selection.is-leaf .el-checkbox {              display: none;            }          }      </style>   三、 <template>   <div>     <el-table       ref="multipleTable"       :data="tableData"       highlight-current-row       @select-all="onSelectAll"       @selection-change="selectItem"       @row-click="onSelectOp"     >       <el-table-column type="selection" width="55" align="center" />       <el-table-column label="序号" type="index" align="center" />       <el-table-column label="姓名" prop="name" align="center" />       <el-table-column label="手机号码" prop="province" align="center" />     </el-table>   </div> </template>   <script> export default {   data() {     return {       tableData: [{           name: '王小虎1',           province: '上海1',         }, {           name: '王小虎2',           province: '上海2',         }, {           name: '王小虎3',           province: '上海3',         }, {           name: '王小虎4',           province: '上海4',         }],     }   },   mounted(){   },   methods: {     onSelectAll() {       this.$refs.multipleTable.clearSelection();     },     selectItem(rows) {       if (rows.length > 1) {         const newRows = rows.filter((it, index) => {           if (index == rows.length - 1) {             this.$refs.multipleTable.toggleRowSelection(it, true);             return true;           } else {             this.$refs.multipleTable.toggleRowSelection(it, false);             return false;           }         });         this.multipleSelection = newRows;       } else {         this.multipleSelection = rows;       }       // this.userId = this.multipleSelection.length? this.multipleSelection[0].guid: "";       console.log('2',this.multipleSelection)     },     onSelectOp(row) {       this.$refs.multipleTable.clearSelection();       this.$refs.multipleTable.toggleRowSelection(row, true);       this.multipleSelection = [];       this.multipleSelection.push(row);     },   } }; </script>

标签:val,refs,表头,element,单选,multipleTable,table,multipleSelection,row
From: https://www.cnblogs.com/ayuaichiyu/p/17502773.html

相关文章

  • 处理致远OA应付科目编码不显示问题,同样适用于付款单选择款项类型后无科目带出
    情况如下:当我们选择预付款时,无任何科目带出 这是由于我们U8的应付设置--基本科目设置中,没有设置预付款对应科目,处理方法如下图,添加上预付款对应科目即可。  ......
  • 使用JTable组件,表头不显示的问题
    问题描述在panel里面添加上table表格时,表头不给予显示,仅仅显示出来表格数据问题解决可以采用ScrollPanel的方式代替掉我们之前使用的JPanel;也可以直接采用JPanel的方式,自主设置表头--JTableHeaderth=table.getTableHeader();,但是我用这种方法还是不行,还得继续查其他资料(基本......
  • elementui 分页page-size current-page 不随着组件改变问题
    问题出在未使用 .sync上!:current-page.sync="pageData.PageIndex":page-size.sync='pageData.PageSize'<el-pagination@size-change="handleSizeChange"@current-change="handleCurrentChange":curren......
  • element ui 穿梭框宽度调整
    elementui穿梭框宽度调整<!--首先穿梭框设置ref用于引用--><el-transferref="grant_transfer"v-model="grant.value":data="grant.data"></el-transfer><script>//....../*穿梭框赋值后*/this.$nextTick(function(){th......
  • ElementUI 获取table中选中的行的两种方式
    Element获取table中选中的行的两种方式<el-tableref="multipleTable":data="data"style="width:100%"border@selection-change="selectionLineChangeHandle"></el-table>   //数据保存data(){return{dataonLineLi......
  • ant design vue的customRender()方法中使用$createElement提示undefined
    antdesignvue的customRender()方法中使用$createElement提示undefined报错信息如下:TypeError:Cannotreadpropertiesofundefined(reading'$createElement')原因:如果index.vue文件中是从另一个columns.js的文件中引用的列配置,在columns.js文件中的customRender()方法中使......
  • Vue3 element-Plus el-tree 权限树 传值给后端及回显问题
    内容:权限在新增人员时候选择传给后端并且编辑回显坑:1.传给后端的权限数组需要传父级id例如:一级目录下有二级目录和2-2目录,选了2-2目录,需要把一级目录的id也给后端2.回显的时候后端会把权限数组id都给你(包括一级目录),如果直接回显的话会默认一级下所有目录都选中 代......
  • 动手开发第一个 SAP Fiori Elements 应用
    本教程的前五篇文章,我们已经为SAPFioriElements的创建做了足够的铺垫。0.迈入SAPFioriElements开发的大门-什么是FioriElements,它和FreestyleUI5开发方式有何区别?1.SAPFioriElements开发环境的搭建和开发准备工作2.在ES5系统注册用户以获得Fiori......
  • Html使用Vue3+ElementPlus(图标 ElMessage)
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"/><metahttp-equiv="X-UA-Compatible"content="IE=edge"/><metaname="viewport"content="wid......
  • vue-element-template|实现登录,根据权限显示路由
    文章目录前言一、安装vue-element-template基础模板?二、具体步骤1.修改路由文件2.挂载前的验证3.获取用户角色,保存一些从后台获得的roles相关信息4.筛选路由5.最后的加载6.别忘了修改登录、推出、获取用户信息路径三、遇到的bug1.datafunctionsshouldreturn......