Vue笔记-浏览器窗口改变时,重新计算表格高度并设置

当窗口大小改变时,你监听 window 对象的 resize 事件,然后在事件处理程序中重新计算表格的高度。在 Vue 中,可以在组件中通过 created 生命周期钩子来添加事件监听器,然后在组件销毁时移除事件监听器。

如下vue代码:

javascript 复制代码
<template>
  <el-table
    :data="tableData"
    :height="tableHeight"
    ref="table"
  >
    <!-- 表格内容 -->
  </el-table>
</template>

<script>
export default {
  data() {
    return {
      tableData: [], // 假设这是你的表格数据
      tableHeight: 0 // 初始高度为0
    };
  },
  created() {
    this.calculateTableHeight(); // 初始化时计算表格高度
    window.addEventListener('resize', this.handleResize); // 添加窗口大小改变事件监听器
  },
  beforeDestroy() {
    window.removeEventListener('resize', this.handleResize); // 在组件销毁前移除事件监听器
  },
  methods: {
    calculateTableHeight() {
      // 这里可以根据需要动态计算表格的高度
      // 例如,获取窗口高度的一定比例等等
      this.tableHeight = window.innerHeight * 0.9; // 将表格高度设置为窗口高度的90%
    },
    handleResize() {
      // 窗口大小改变时触发的事件处理程序
      this.calculateTableHeight(); // 重新计算表格高度
      // 还可以根据需要重新加载表格数据等操作
    }
  }
};
</script>

在这个示例中,在 created 生命周期钩子中添加了窗口大小改变事件的监听器,并在 beforeDestroy 钩子中移除了监听器,以避免内存泄漏。当窗口大小改变时,handleResize 方法会被调用,重新计算表格的高度并更新视图。

相关推荐
来生硬件工程师几秒前
【程序库】 MutiButton 按键库
c语言·笔记·stm32·单片机·mcu·嵌入式实时数据库
雾岛听风6914 分钟前
JavaScript基础语法速查手册
开发语言·前端·javascript
前端那点事8 分钟前
Vue前端SEO优化全攻略(实操落地版,新手也能上手)
前端·vue.js
白夜111723 分钟前
C++任务调度与状态机
开发语言·c++·笔记
用户23678298016823 分钟前
从零实现 GIF 制作工具:LZW 压缩与 Median Cut 色彩量化
前端·javascript
棉猴36 分钟前
Python海龟绘图之绘制文本
javascript·python·html·write·turtle·海龟绘图·输出文本
计算机学姐1 小时前
基于微信小程序的校园失物招领管理系统【uniapp+springboot+vue】
java·vue.js·spring boot·mysql·信息可视化·微信小程序·uni-app
xian_wwq1 小时前
【学习笔记】储能系统的铁三角:BMS、PCS、EMS分别管啥
笔记·学习·储能系统
中屹指纹浏览器1 小时前
指纹浏览器自动化测试中的环境一致性与稳定性保障
经验分享·笔记
Highcharts.js1 小时前
线形比赛积分增长或竞赛图|Highcharts企业图表代码示列
开发语言·前端·javascript·折线图·highcharts·竞赛图