vue element admin 如何修改组件el-tabs的高度

如图所示,当没有数据时,el-tabs不能撑开高度到底,如何设置

img

提个建议你可以尝试一下,通过前端调试工具,找到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)
  }
}

img

https://element.eleme.cn/#/zh-CN/component/table