方法一、css + js的形式
这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要使用calc来设置高度,然后给表格设置:height="tableh"的属性
<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>
态获取表格高度tableh的方法
<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的形式
还是需要在表格外加一层div,div高度设置和方法一相同,不过表格高度不用动态设置,直接设置height="100%"即可
方法三、指令的形式
这种方法不需要设置外层div,定义一个文件夹tableheight分别定义一个tableheight.js和index.js
tableheight.js如下
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) } }
ndex.js如下
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
用方式,在main.js里面引入以便全局使用,当然你也可以局部引入
main.js
// 这个是你刚刚写的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>
以上就是vue基于elementui动态设置表格高度的3种方法的详细内容,更多关于vue基于elementui动态设置表格动态高度的3种方法的资料请关注代码网其它相关文章!
发表评论