【UI】element ui table(表格)expand实现点击一行展开功能

前言

element ui是一个非常不错的vue的UI框架,element对table进行了封装,简化了vue对表格的渲染。
element ui表格中有一个功能是展开行,在2.0版本官网例子中,只可以点击右箭头可以展开,我们的很多需求是点击某一行展开,那是不是无法实现呢?其实,借助element ui的一些属性,轻松实现点击某行展开,我们还是用2.0.9版本官网的例子

可以看到官方代码中在这边没有让这个可展开table自动折叠的功能,我点击了别的标签页后上次点击的行仍旧处在一个展开的状态,而且操控的方式也只能点击到左上角的小箭头才可以控制行的展开状态,体验不是特别好,可以说有点糟糕了,但是我后来在后面的文档中发现The methods 里面有写到一个方法叫toggleRowExpansion,这个方法应该是官方本意上想让我们来自由控制展开状态的,从传递的两个参数来看,一个是row(当前点击的行id),另一个是expended(行展开状态,boolean值),看上去有理有据,但是就是不知道怎么用,因为我始终无法获取到expended这个参数的值,有点气,所以这次我们用另一种方式来实现这个功能。

参考文章:
element ui table(表格)实现点击一行展开功能
使用element-ui中table expand展开行控制显示隐藏,隐藏小箭头列的方法,之展开一行内容
使用element-ui中table expand展开行控制显示隐藏(手风琴效果)

在这里插入图片描述

涉及知识点:

1、不点击小箭头,点击其他列中的某个按钮展开行内容。

2、隐藏小箭头列(既然我们点击表格其他单元格展开行内容了,一般就不需要小箭头列了)

3、只展开一行内容

代码部分

对齐改造,使之可以做到这点

<template>
 <el-table
   :data="tableData5"
   style="width: 100%"
   @row-click="handleRowClick"
   ref="expandableTable">
  <el-table-column type="expand">
   <template slot-scope="props">
    <el-form label-position="left" inline class="demo-table-expand">
     <el-form-item label="商品名称">
      <span>{{ props.row.name }}</span>
     </el-form-item>
     <el-form-item label="所属店铺">
      <span>{{ props.row.shop }}</span>
     </el-form-item>
     <el-form-item label="商品 ID">
      <span>{{ props.row.id }}</span>
     </el-form-item>
     <el-form-item label="店铺 ID">
      <span>{{ props.row.shopId }}</span>
     </el-form-item>
     <el-form-item label="商品分类">
      <span>{{ props.row.category }}</span>
     </el-form-item>
     <el-form-item label="店铺地址">
      <span>{{ props.row.address }}</span>
     </el-form-item>
     <el-form-item label="商品描述">
      <span>{{ props.row.desc }}</span>
     </el-form-item>
    </el-form>
   </template>
  </el-table-column>
  <el-table-column
    label="商品 ID"
    prop="id">
  </el-table-column>
  <el-table-column
    label="商品名称"
    prop="name">
  </el-table-column>
  <el-table-column
    label="描述"
    prop="desc">
  </el-table-column>
 </el-table>
</template>
 
<style>
 .demo-table-expand {
  font-size: 0;
 }
 .demo-table-expand label {
  width: 90px;
  color: #99a9bf;
 }
 .demo-table-expand .el-form-item {
  margin-right: 0;
  margin-bottom: 0;
  width: 50%;
 }
</style>
 
<script>
 export default {
  data() {
   return {
    tableData5: [{
     id: '12987122',
     name: '好滋好味鸡蛋仔',
     category: '江浙小吃、小吃零食',
     desc: '荷兰优质淡奶,奶香浓而不腻',
     address: '上海市普陀区真北路',
     shop: '王小虎夫妻店',
     shopId: '10333'
    }, {
     id: '12987123',
     name: '好滋好味鸡蛋仔',
     category: '江浙小吃、小吃零食',
     desc: '荷兰优质淡奶,奶香浓而不腻',
     address: '上海市普陀区真北路',
     shop: '王小虎夫妻店',
     shopId: '10333'
    }, {
     id: '12987125',
     name: '好滋好味鸡蛋仔',
     category: '江浙小吃、小吃零食',
     desc: '荷兰优质淡奶,奶香浓而不腻',
     address: '上海市普陀区真北路',
     shop: '王小虎夫妻店',
     shopId: '10333'
    }, {
     id: '12987126',
     name: '好滋好味鸡蛋仔',
     category: '江浙小吃、小吃零食',
     desc: '荷兰优质淡奶,奶香浓而不腻',
     address: '上海市普陀区真北路',
     shop: '王小虎夫妻店',
     shopId: '10333'
    }],
   }
  },
  methods:{
  	handleRowClick(row, event, column) {
      this.$refs.expandableTable.toggleRowExpansion(row);
    },
  }
 
 }
</script>

这个例子可以直接复制运行起来,一点问题都没有,上面的代码可以实现点击某行展开,对比官网的例子,我们在table添加了

@row-click="handleRowClick"
ref="expandableTable"

隐藏小箭头

自己项目中遇到的问题是想要隐藏小箭头列,无意间发现这篇文章,原来只需要设置 width="1" 就行了。

因为我设置了<el-table-column type="expand" width="1"></el-table-column> 会多出1px的边距,所以我们可以再在最外层放一个空的div,设置样式overflow:hidden;
再设置此table的样式margin-left:1px;好了,完美实现。(自己的项目中没有遇到1px影响效果的情况,可以直接设置宽度为1px即可)

放上项目最终的效果图,无多出的1px边框。

在这里插入图片描述

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

  • 15
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在Element UI中,可以使用Table组件来嵌套表格。具体实现方法是在Table的columns中定义一个子表格的column,然后在父表格的数据中添加一个子表格的数据数组。当用户点击表格的某一行时,子表格展开并显示对应的子表格数据。同时,可以通过设置expand-row-keys属性来控制哪些行需要展开表格。 ### 回答2: Element UI中的Table组件是一个非常常用的表格组件,提供了非常灵活的表格展示和操作。而嵌套表格则是在Table中的一种比较特殊的展示方式,可用于在当前表格内,在某些行的详细信息下展开一张子表格。 使用Element UITable嵌套表格,有以下几个基本步骤: 1.首先需要在父表格(主表格)的columns中添加一个slot来展示子表格的内容: ```javascript columns: [ { label: '姓名', prop: 'name' }, { label: '年龄', prop: 'age' }, { label: '操作', slot: 'actions' } ] ``` 在父表格的上述例子中,我们为“操作”列添加了一个`slot: 'actions'`,这里的actions是指在子组件中要用到的那个slot名字,代表着在子表格中要插入的内容。 2.添加子表格组件,并在子组件中通过slot-scope获取父子数据并展示子表格数据: ```vue <template> <el-table :data="data" style="width: 100%"> <el-table-column prop="date" label="日期" width="180"> </el-table-column> <el-table-column prop="name" label="姓名"> </el-table-column> <el-table-column prop="address" label="地址"> </el-table-column> </el-table> </template> <script> export default { props: { prop: String, row: Object }, data() { return { data: [ { date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { date: '2016-05-04', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { date: '2016-05-01', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { date: '2016-05-03', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, ] } } } </script> ``` 在子组件中我们通过父组件传递过来的数据`prop: String, row: Object`作为查询参数,来获取展示子表格的数据,并通过`slot-scope`在父组件中添加插槽来展示子组件内容。 3.在父组件中的操作列中通过scoped slot插入子组件: ```vue <el-table-column label="操作" width="120"> <template slot-scope="scope"> <el-button type="primary" @click.prevent.stop="handleOpen(scope.row)"> 添加子表格 </el-button> <el-table :data="[scope.row]" v-show="scope.row.children && scope.row.children.length > 0"> <el-table-column type="expand" label=""> <template slot-scope="props"> <children-table :prop="scope.column.prop" :row="props.row"> </children-table> </template> </el-table-column> </el-table> </template> </el-table-column> ``` 父组件中的操作列中包含了一个添加子表格的按钮和一个子表格展开的图标,当用户点击添加子表格的时候,会调用handleOpen方法,在此方法中可以进行一些列操作,比如网络请求,获取子表格数据等等。当用户点击表格展开的图标时,会展开表格,进而呈现子组件中的内容。 总的来说,Element UI中的Table嵌套表格是一种非常常见的表格展示方式,可以帮助用户更加详细地了解表格数据内容,在实际开发中应用也比较广泛,值得学习和掌握。 ### 回答3: 随着前端开发的不断发展,表格是展示数据的重要组件之一。Element UI是基于Vue.jsUI组件库,提供了功能强大、易于使用的表格组件,可以快速地实现各种表格需求。在很多情况下,在一个表格中嵌套另一个表格是一种特殊的需求,这时候我们可以借助Element UITable插槽来实现。 在Element UI中,给表格设置scoped-slot,即插槽,可以在每一行的数据中增加自己想要的内容,这样就可以通过插槽嵌套表格。 嵌套表格的特别之处在于数据源的构造。外层表格中每一行的数据需要嵌套表格所需的子数据。在表格中设置scoped-slot之后,可以通过js的逻辑处理来为每一行数据增加子数据属性,使得在一行数据中展示一个表格,并向里面传入嵌套表格所需的子数据。 除此之外,Element UI也提供了一些便捷的函数和属性以处理复杂的嵌套表格需求。嵌套表格的cell-style、row-style、fixed、selection、index等属性都可以灵活配合使用,使得表格嵌套表格以及数据的展示更加灵活多样。同时还有一些针对单元格的通用插槽,如cell、header-cell、expand等,可以快速地实现单元格的自定义展示。 总的来说,在Element UI中嵌套表格是一种非常强大的功能,用于复杂和大型数据集的展示,提供了丰富的组件和插槽,可以灵活地满足各种嵌套表格需求。通过使用这些方法,不仅可以快速地构建数据展示,同时也提升了用户的体验感。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fruge365

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值