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;
相关推荐
wen's1 小时前
React Native 0.79.4 中 [RCTView setColor:] 崩溃问题完整解决方案
javascript·react native·react.js
vvilkim1 小时前
Electron 自动更新机制详解:实现无缝应用升级
前端·javascript·electron
vvilkim1 小时前
Electron 应用中的内容安全策略 (CSP) 全面指南
前端·javascript·electron
aha-凯心2 小时前
vben 之 axios 封装
前端·javascript·学习
漫谈网络2 小时前
WebSocket 在前后端的完整使用流程
javascript·python·websocket
失落的多巴胺3 小时前
使用deepseek制作“喝什么奶茶”随机抽签小网页
javascript·css·css3·html5
DataGear3 小时前
如何在DataGear 5.4.1 中快速制作SQL服务端分页的数据表格看板
javascript·数据库·sql·信息可视化·数据分析·echarts·数据可视化
影子信息3 小时前
vue 前端动态导入文件 import.meta.glob
前端·javascript·vue.js
青阳流月3 小时前
1.vue权衡的艺术
前端·vue.js·开源
RunsenLIu3 小时前
基于Vue.js + Node.js + MySQL实现的图书销售管理系统
vue.js·mysql·node.js