
表头标题是重复的、为了能看到滚动效果
v-if="lists[0].ispass" 来判断表格列的状态每一列是否显示或隐藏 勾选则展示、取消勾选隐藏、默认勾选
<el-dropdown :hide-on-click="false">
<i class="iconfont icon-shaixuan" ></i>
<el-dropdown-menu slot="dropdown" >
<el-scrollbar style="height: 60vh">//作用是数据过多把表单数据的整体高度固定、多出的区域可以下拉展示
<el-checkbox-group v-model="check">
<el-dropdown-item v-for="(item,index) in checkList" :key="index"><el-checkbox :label="item" :key="item"></el-checkbox>
</el-dropdown-item>
</el-checkbox-group>
</el-scrollbar>
</el-dropdown-menu>
</el-dropdown>
<el-table :data="institutionalTypeList" border align="center" v-loading="listLoading" style="width: 100%" :header-cell-style="tableBg">
<af-table-column type="index" :index="indexMethod" label="序号" width="90">
</af-table-column>
<af-table-column v-if="lists[0].ispass" prop="id" label="编码" >
</af-table-column>
<af-table-column v-if="lists[1].ispass" prop="name" label="名称" >
</af-table-column>
<af-table-column v-if="lists[2].ispass" prop="updatetime" label="更新时间" >
</af-table-column>
</el-table>
lists是所有表头标题,check是多选框默认全选,checkList也是所有表头标题、跟多选框绑定的
data() {
return {
check:['编码','名称','更新时间'],
checkList:['编码','名称','更新时间'],
lists:[
{label:'编码',ispass:true},
{label:'名称',ispass:true},
{label:'更新时间',ispass:true},
],
}
},
动态监听值选中的选项
watch:{
check(newVal){
if (newVal) {
var arr = this.checkList.filter(i =>newVal.indexOf(i) <0) //未选中
this.lists.map(i =>{
if (arr.indexOf(i.label) !== -1) {
i.ispass = false
} else {
i.ispass = true
}
})
}
}
},
el-table内容过多的时候可以设置 show-overflow-tooltip为 true,这样可以设置实现超出隐藏功能。但是这个方法有些问题:
先看下效果
如果拖动表头宽度,改变列的宽度,也可以适应。
能实现上述效果主要是能获取到列的width和realWidth 这2个字段的值(目前这个版本是可以获取到的),不拖动表头宽度的时候获取的是width字段,拖动表头后获取realWidth .
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)