vue基于ElementUI动态设置表格高度的3种方法
方法一、css + js的形式
这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要使用calc来设置高度,然后给表格设置:height="tableH"的属性
外层div高度的设置方法
//这里减去的是你个人业务除了表格之外其他内容的高度,比如查询条件等
态获取表格高度tableH的方法
方法二、纯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就是除了表格之外其他内容的高度,比如查询条件等 // 指令的好处是会监听屏幕的变化来动态改变高度
以上就是vue基于ElementUI动态设置表格高度的3种方法的详细内容,更多关于vue基于ElementUI动态设置表格动态高度的3种方法的资料请关注科站长其它相关文章!
上一篇:javascript中本地存储localStorage,sessionStorage,cookie,indexDB的用法与使用场景汇总
栏 目:JavaScript
本文标题:vue基于ElementUI动态设置表格高度的3种方法
本文地址:https://www.fushidao.cc/wangluobiancheng/3135.html
您可能感兴趣的文章
- 02-11js中基本事件的总结(onclick、onblur、onchange等)
- 02-11详解如何在Node.js中使用中间件处理请求
- 02-11Vue3中Provide和Inject的用法及工作原理详解
- 02-11Vue+vant实现图片上传添加水印
- 02-11快速解决 keep-alive 缓存组件中定时器干扰问题
- 02-11uniapp 使用 tree.js 解决模型加载不出来的问题及解决方法
- 02-11基于uniapp vue3 的滑动抢单组件实例代码
- 02-10JavaScript 中的 Map使用指南
- 02-10vue3中使用print-js组件实现打印操作步骤
- 02-10Vue 中v-model的完整用法及v-model的实现原理解析


阅读排行
推荐教程
- 04-23JavaScript Array实例方法flat的实现
- 04-23THREE.JS使用TransformControls对模型拖拽的代码实例
- 04-23Vue3使用v-if指令进行条件渲染的实例代码
- 04-23vue3+ts项目搭建的实现示例
- 04-23JavaScript实现下载超大文件的方法详解
- 04-23vue如何使用pdf.js实现在线查看pdf文件功能
- 04-23vue.js调用python脚本并给脚本传数据
- 12-18使用JavaScript遍历输出页面中的所有元素的方法详解
- 04-23JS加密解密之保存到桌面书签
- 12-18Vue实现滚动加载更多效果的示例代码