如图所示,当没有数据时,el-tabs不能撑开高度到底,如何设置
提个建议你可以尝试一下,通过前端调试工具,找到el-tabs对应css,然后在自己的css里定义一个同名的样式,在复制框架自带的样式以外,加一个min-height属性,把最小高度撑到你需要的高度,这个方法应该实用与所有框架,在框架本身不支持的前提下,都可以尝试自定义
设置一个行高,可以添加一个最小高度
想办法将高度设置为页面可视高度window.innerHeight
希望对你有用:【解决element-ui中多个table在tab切换时出现高度、宽度缩小的问题,适用所用情况】https://mbd.baidu.com/ma/s/qyJmTZiE
监听tableData数组 如果有数据自动撑开 如果没有 height或者max-height 设置一个高度 就能自动撑开了
参见文档 https://element.eleme.cn/#/zh-CN/component/table#table-column-scoped-slot
<div class="tableHeight">
<el-table :data="table" border style="width: 100%" height="100%">
<el-table-column label="序号" :show-overflow-tooltip="true" type="index" width="60" align="center">
</el-table-column>
<el-table-column prop="name" :show-overflow-tooltip="true" align="center" label="单位名称">
</el-table-column>
</el-table>
</div>
//:show-overflow-tooltip="true" 这个是内容超出以后会显示省略号
.tableHeight {
width:100%;
height: calc(100vh - 225px); //可以根据不同屏幕实现自适应高度 225可以修改自己适合的高度 100vh就是一屏的高度
}
在el-table标签上添加max-height属性,然后设置值为200,用于设置最大高度不超过200px。
<el-table:data="tableData" max-height="200">
动态设置高度
#//1 index.js
import tableHeight from './tableHeight'
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)
2、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) || 52
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)
}
}