当前位置: 代码网 > it编程>编程语言>Javascript > vue基于ElementUI动态设置表格高度的3种方法

vue基于ElementUI动态设置表格高度的3种方法

2025年02月13日 Javascript 我要评论
方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要使用calc来设置高度,然后给表格设置:height="ta

方法一、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种方法的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com