elementplus根据弹窗高度设置table高度

弹窗里要放一个table表格,表格高度跟随弹窗高度的变化而变化。

代码如下:

javascript 复制代码
<template>
	<el-dialog ref="lookDialogRef" v-model="dialogLook.visible" :title="dialogLook.title" width="1000px" append-to-body @close="closeDialog" @open="openDialog">
		<el-table :data="tableData" :height="dialogHeight">
	        <el-table-column v-if="true" label="编号" align="center" prop="code" />
	        <el-table-column v-if="true" label="姓名" align="center" prop="name" />
	        <el-table-column v-if="true" label="年龄" align="center" prop="age" />
	    </el-table>
	</el-dialog>
</template>

<script setup lang="ts">
const dialogHeight = ref('200px')
const lookDialogRef = ref(null)
const lookDialog = () => {
    console.log(lookDialogRef.value.$el.querySelector('.el-dialog__body'))
}
onMounted(() => {
    window.onresize = () => {
        dialogLook.visible && lookDialog()
    }
})
</script>
            

报错如下:

原因:写法有问题。

javascript 复制代码
//少写了一个dialogContentRef
console.log(lookDialogRef.value.dialogContentRef.$el.querySelector('.el-dialog__body'))

知识点:

‌ElementPlus中的dialogContentRef是一个引用(ref),用于获取`el-dialog组件内部的具体DOM元素,特别是对话框的内容区域。‌

在ElementPlus中,el-dialog组件提供了dialogContentRef属性,通过这个属性可以获取到对话框内容的DOM元素。这在进行一些自定义操作时非常有用,比如动态设置对话框内容的高度、宽度或者进行其他DOM操作。

最终代码:(获取元素可视高度)

javascript 复制代码
<template>
	<el-dialog ref="lookDialogRef" v-model="dialogLook.visible" :title="dialogLook.title" width="1000px" append-to-body @close="closeDialog" @open="openDialog">
		<el-table :data="tableData" :height="tableHeight">
	        <el-table-column v-if="true" label="编号" align="center" prop="code" />
	        <el-table-column v-if="true" label="姓名" align="center" prop="name" />
	        <el-table-column v-if="true" label="年龄" align="center" prop="age" />
	    </el-table>
	</el-dialog>
</template>

<script setup lang="ts">
const tableHeight = ref('200px')
const lookDialogRef = ref(null)
const openDialog = () => {
    nextTick(() => {
        let h = lookDialogRef.value.dialogContentRef.$el.querySelector('.el-dialog__body').clientHeight - 130
        tableHeight.value = h + 'px'
    })
}
onMounted(() => {
    window.onresize = () => {
       dialogLook.visible && openDialog()
    }
})
</script>

注:

javascript 复制代码
// 获取实际高度(包括padding和border)
const actualHeight = element.offsetHeight;

// 获取可视高度(不包括滚动条)
const visualHeight = element.clientHeight;
相关推荐
灵感__idea几秒前
JavaScript高级程序设计(第5版):前端的能力边界
前端·javascript·程序员
华洛2 分钟前
SEO还没死,GEO之战已经开始
前端·javascript·产品
不想上班只想要钱21 分钟前
vue3 ts:声明的一个数组不能将类型“boolean”分配给类型“never”。
前端·vue.js
F2E_Zhangmo3 小时前
基于cornerstone3D的dicom影像浏览器 第三章 拖拽seriesItem至displayer上显示第一张dicom
前端·javascript·cornerstone·cornerstone3d·cornerstonejs
gnip8 小时前
Jst执行上下文栈和变量对象
前端·javascript
拉不动的猪9 小时前
简单回顾下Weakmap在vue中为何不能去作为循环数据源,以及替代方案
前端·javascript·vue.js
How_doyou_do9 小时前
数据传输优化-异步不阻塞处理增强首屏体验
开发语言·前端·javascript
DT——10 小时前
前端登录鉴权详解
前端·javascript
界面开发小八哥11 小时前
数据可视化图表库LightningChart JS v8.0上线:全新图例系统 + 数据集重构
javascript·信息可视化·数据可视化·lightningchart
烛阴11 小时前
【TS 设计模式完全指南】从“入门”到“劝退”,彻底搞懂单例模式
javascript·设计模式·typescript