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;
相关推荐
阿珊和她的猫3 小时前
v-scale-scree: 根据屏幕尺寸缩放内容
开发语言·前端·javascript
gnip8 小时前
vite和webpack打包结构控制
前端·javascript
草梅友仁9 小时前
草梅 Auth 1.4.0 发布与 ESLint v9 更新 | 2025 年第 33 周草梅周报
vue.js·github·nuxt.js
烛阴10 小时前
前端必会:如何创建一个可随时取消的定时器
前端·javascript·typescript
萌萌哒草头将军11 小时前
Oxc 最新 Transformer Alpha 功能速览! 🚀🚀🚀
前端·javascript·vue.js
武昌库里写JAVA11 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习
1024小神12 小时前
nextjs项目build导出静态文件
前端·javascript
parade岁月12 小时前
JavaScript 日期的奇妙冒险:当 UTC 遇上 el-date-picker
javascript
是一碗螺丝粉12 小时前
拯救你的app/小程序审核!一套完美避开审核封禁的URL黑名单机制
前端·javascript·微信小程序
littleding12 小时前
Vue3之计算属性
前端·vue.js