vue基于elementui设置表格动态高度的几种方法

方法一 css + js的形式

<div class="table-wrapper" ref="tableWrapper" v-loading="loading"> <el-table :data="tableData" stripe style="width: 100%" :height="tableH"> <el-table-column prop="date" label="日期" width="180"> </el-table-column> <el-table-column prop="name" label="姓名" width="180"> </el-table-column> <el-table-column prop="address" label="地址"> </el-table-column> </el-table> </div> 最外层div高度的设置方法

//这里减去的是你个人业务除了表格之外其他内容的高度,比如查询条件等 <style lang="scss" scoped> .table-wrapper { height: calc(100% - 60px); } </style>

<script> // 在data里面初始化tableH data() { return { tableH: 0 } }, methods: { // 重置table高度 resetHeight() { return new Promise((resolve, reject) => { this.tableH = 0 resolve() }) }, // 设置table高度 fetTableHeight() { this.resetHeight().then(res => { this.tableH = this.$refs.tableWrapper.getBoundingClientRect().height - 10 }) } }, // 调用 mounted() { this.fetTableHeight(); } </script>

方法二 纯css的形式
方法三 指令的形式

import { addResizeListener, removeResizeListener } from 'element-ui/src/utils/resize-event' // 设置表格高度 const doResize = async (el, binding, vnode) => { // 获取表格Dom对象 const { componentInstance: $table } = await vnode // 获取调用传递过来的数据 const { value } = binding // if (!$table.height) { // throw new Error(`el-$table must set the height. Such as height='100px'`) // } // console.log($table, '$table$table$table$table') // 获取距底部距离(用于展示页码等信息) const bottomOffset = (value && value.bottomOffset) || 30 if (!$table) return // 计算列表高度并设置 const height = window.innerHeight - el.getBoundingClientRect().top - bottomOffset // $table.layout.setMaxHeight(height) $table.layout.setHeight(height) // $table.maxHeight = height $table.doLayout() } export default { // 初始化设置 bind(el, binding, vnode) { // 设置resize监听方法 el.resizeListener = async () => { await doResize(el, binding, vnode) } // 绑定监听方法到addResizeListener addResizeListener(window.document.body, el.resizeListener) }, // // 绑定默认高度 async inserted(el, binding, vnode) { await doResize(el, binding, vnode) }, // // 销毁时设置 unbind(el) { // 移除resize监听 removeResizeListener(el, el.resizeListener) } }

import tableHeight from './table-height' const install = function(Vue) { // 绑定v-adaptive指令 Vue.directive('tableHeight', tableHeight) } if (window.Vue) { window['tableHeight'] = tableHeight // eslint-disable-next-line no-undef Vue.use(install) } tableHeight.install = install export default tableHeight

// 这个是你刚刚写的index.js的路径 import tableHeight from '@sysmng/directive/tableHeight' // 表格自适应指令 Vue.use(tableHeight)

// 这里需要设置一个默认的高度,多少都可以,然后后面的60就是除了表格之外其他内容的高度,比如查询条件等
// 指令的好处是会监听屏幕的变化来动态改变高度
<el-table :data="tableData" stripe style="width: 100%" height="100px" v-tableHeight="{bottomOffset: 60}">
    <el-table-column
      prop="date"
      label="日期"
      width="180">
    </el-table-column>
    <el-table-column
      prop="name"
      label="姓名"
      width="180">
    </el-table-column>
    <el-table-column
      prop="address"
      label="地址">
    </el-table-column>
 </el-table>

本文章由javascript技术分享原创和收集

发表评论 (审核通过后显示评论):