vue2设置el-table自适应高度

  • 表格属性和样式:
<el-table
highlight-current-row
:data="PlannedData"
style="width: 100%"
:header-cell-style="tableHeaderCellStyle"
:cell-style="tableCellStyle"
@sort-change="handleSortChange"
:max-height="tableHeight"
>

  • highlight-current-row: 表示高亮当前行。
  • :data="PlannedData": 表示表格的数据来源,其中PlannedData是数据的变量名。
  • style="width: 100%": 设置表格宽度为100%。
  • :header-cell-style="tableHeaderCellStyle": 设置表头单元格的样式。
  • :cell-style="tableCellStyle": 设置表格内容单元格的样式。
  • @sort-change="handleSortChange": 监听表格排序变化,触发handleSortChange方法。
  • :max-height="tableHeight": 设置表格的最大高度

 

  • 窗口大小变化监听和表格高度计算:
data() {
return {
  tableHeight: this.calculateTableHeight(), // 初始化表格高度
};
},
mounted() {
// 监听窗口大小变化,实时更新表格高度
window.addEventListener('resize', this.handleResize);
},
methods: {
handleResize() {
  // 窗口大小变化时重新计算表格高度
  this.tableHeight = this.calculateTableHeight();
},
calculateTableHeight() {
  // 根据实际需求计算表格高度
  return window.innerHeight - 25;
},
},
destroyed() {
// 组件销毁时移除事件监听
window.removeEventListener('resize', this.handleResize);
},
  • tableHeight: 表示表格的高度,通过calculateTableHeight方法计算得到,并在组件初始化时进行了初始化。
  • mounted生命周期中,添加了窗口大小变化事件监听器,当窗口大小变化时,调用handleResize方法重新计算表格高度。
  • calculateTableHeight方法根据实际需求计算表格高度,这里是将窗口高度减去一个固定值(25)根据实际效果填写值
  • 表格样式
computed: {
tableHeaderCellStyle() {
  return {
  color: '#000',
  fontSize: '12px',
  fontFamily: '微软雅黑',
  textAlign: 'center',
  padding: 0,
  margin: 0,
  };
},
tableCellStyle() {
  return {
  fontSize: '11px',
  textAlign: 'center',
  padding: 0,
  margin: 0,
  };
},
},
  • 通过computed属性计算了两个样式对象,分别用于表头和表格内容的样式设置。
  • 组件销毁时移除事件监听
destroyed() {
// 组件销毁时移除事件监听
window.removeEventListener('resize', this.handleResize);
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue2.0和ElementUI2.0中使用el-table表格组件时,自适应高度可以通过以下步骤来实现: 1. 确定数据源 首先,我们需要确定用于填充表格的数据源。在el-table中,数据通常以数组的形式传递,其中每个数组元素代表表格中的一行数据。 2. 计算表格高度Vue中,我们可以使用计算属性来动态计算表格高度。计算属性会根据数据源的变化自动更新表格高度。例如,我们可以使用下面的代码来计算表格高度: computed: { tableHeight: function() { // 获取窗口可见区域高度 var viewportHeight = window.innerHeight; // 计算表格头和分页组件的高度 var tableHeaderHeight = this.$refs.table.$el.querySelector('.el-table__header-wrapper').offsetHeight; var paginationHeight = this.$refs.pagination.$el.offsetHeight; // 计算表格内容区域的高度 var contentHeight = viewportHeight - tableHeaderHeight - paginationHeight - 20; return contentHeight; } } 在上面的代码中,我们首先获取窗口可见区域的高度,然后根据表格头和分页组件的高度计算表格内容区域的高度。最后,将计算出的高度返回。 3. 绑定表格高度 我们将计算属性中计算出的表格高度绑定到el-table组件中的height属性上,以实现自适应高度。例如,我们可以使用下面的代码将表格高度绑定到el-table组件上: <el-table :data="tableData" ref="table" :height="tableHeight"> 在上面的代码中,我们首先使用data属性传递数据源,然后使用ref属性给el-table组件添加一个引用,最后使用height属性将计算属性中计算出的表格高度绑定到组件上。 通过上述方法,我们可以在Vue2.0和ElementUI2.0中实现自适应高度el-table表格组件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值