ElementUI el-table 在flex下的宽度自适应问题
2018-07-21 14:21
1946 查看
BUG:在flex容器下面的一个
flex:1的子容器里面写了个
el-table用来展示列表数据,在做宽度自适应测试的时候发现该组件的宽度只会增加不会缩小。
Debug:通过控制台发现组件生成的
table的宽度是动态计算的,翻查源码,发现以下代码段
// table.vue if (this.fit) { addResizeListener(this.$el, this.resizeListener); } // resize-event.js export const addResizeListener = function(element, fn) { if (isServer) return; if (!element.__resizeListeners__) { element.__resizeListeners__ = []; element.__ro__ = new ResizeObserver(resizeHandler); element.__ro__.observe(element); } element.__resizeListeners__.push(fn); };
也就是说,组件的
resize事件是绑定在
this.$el上了,这应该就是的原因所在了。
flex容器下的
width:100%会一直向上继承,直到flex容器下第一级子元素,但是当某个子元素的宽度出现固定值并且大于flex伸展的宽度的时候,那么容器就不会收缩,自然也就触发不了
resize事件了。
解决方案:可以将设置了
flex属性的容器设置
position:relative,然后在子元素加多一层div包裹内容,设置
position:absolute; width:100%;继承父级宽度,那么内容也会继承该div的宽度了。 阅读更多
相关文章推荐
- element-ui的table组件在flex布局下的宽高自适应
- Element UI的表格table列的宽度自适应设置
- Element-ui树形控件el-tree使用过程中遇到的问题
- vue2.0 + element UI 中 el-table 数据导出Excel的方法
- VueJS ElementUI el-table 的 formatter 和 scope template 不能同时存在
- 解决vue2.0 element-ui中el-upload的before-upload方法返回false时submit()不生效问题
- 解决使用elementUI框架el-upload上传组件时session丢失问题
- vue+elementUI中使用 el-autocomplete 实现远程搜索的下拉框需要注意的问题
- vue+elementui的table行内实现el-upload文件添加/多文件上传
- Element-UI在safari浏览器下table列表无法对齐的问题
- 详解VUE 对element-ui中的ElTableColumn扩展
- vue+element ui 使用$refs获取el-dialog 下的 el-table 组件 ,以及使用table多选,默认选中
- 前端踩坑小结:当elementui的el-dialog组件中包含子组件时,用refs调用子组件时的undefined问题
- Element-UI table排序问题
- 解决element-ui中el-menu组件作为vue-router模式在刷新页面后default-active属性与当前路由页面不一致问题的方法
- Vue2.0 UI框架Element运用之DateTimePicker(el-date-picker)初始值及时间格式转化等细节问题
- 当你用element-ui遇到需要在el-table-column上v-for时,这篇文章你能用的上,也就是你需要二级循环
- VueJS ElementUI el-table 的 formatter 和 scope template 不能同时存在
- 使用Element-ui的Table时表格不能显示问题
- element-ui 中的table的列隐藏问题解决