vue+elementUI配置表格的列显示与隐藏

vue+elementUI配置表格的列显示与隐藏

描述:
表格的列过多时,可以根据需要控制列的显示与隐藏,目前是采用Vue+elementUI(适配Vue3的Element Plus)实现的,具体效果与代码如下:
效果图:
在这里插入图片描述

完整代码:

<template>
  <div id="app">
    <el-table :data="tableData" border style="width: 100%" ref="table">
      <el-table-column
        fixed
        type="index"
        align="center"
        :index="1">
        <template #header>
          <el-popover
            placement="bottom"
            :width="600"
            :visible="visible"
          >
            <!-- 配置列面板 -->
            <transition name="fade">
              <div>
                <div>选择显示字段</div>
                <div>
                  <el-checkbox v-model="showColumn.date" disabled>日期</el-checkbox>
                  <el-checkbox v-model="showColumn.name">姓名</el-checkbox>
                  <el-checkbox v-model="showColumn.provinces">省份</el-checkbox>
                  <el-checkbox v-model="showColumn.city">市区</el-checkbox>
                  <el-checkbox v-model="showColumn.adreess">地址</el-checkbox>
                  <el-checkbox v-model="showColumn.zipCode">邮编</el-checkbox>
                </div>
              </div>
            </transition>
            <div style="text-align: right; margin: 0">
              <el-button size="mini" type="text" @click="visible = false">取消</el-button>
              <el-button size="mini" type="primary" plain @click="saveColumn">确定</el-button>
            </div>
            <template #reference>
              <i
                class="el-icon-setting"
                style="font-size: 22px; cursor: pointer"
                @click="visible = true"
              ></i>
            </template>
          </el-popover>
        </template>
      </el-table-column>
      <el-table-column
        prop="date"
        label="日期"
        width="150"
        v-if="showColumn.date"
      >
      </el-table-column>
      <el-table-column
        prop="name"
        label="姓名"
        width="120"
        v-if="showColumn.name"
      >
      </el-table-column>
      <el-table-column
        prop="province"
        label="省份"
        width="120"
        v-if="showColumn.provinces"
      >
      </el-table-column>
      <el-table-column
        prop="city"
        label="市区"
        width="120"
        v-if="showColumn.city"
      >
      </el-table-column>
      <el-table-column
        prop="address"
        label="地址"
        minWidth="300"
        v-if="showColumn.adreess"
      >
      </el-table-column>
      <el-table-column
        prop="zip"
        label="邮编"
        width="120"
        v-if="showColumn.zipCode"
      >
      </el-table-column>
      <el-table-column label="操作" fixed="right" width="100" align="center">
        <template #default="scope">
          <el-button @click="handleClick(scope.row)" type="text" size="small"
            >查看</el-button
          >
          <el-button type="text" size="small">编辑</el-button>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      visible: false,
      tableData: [
        {
          date: "2016-05-02",
          name: "王小虎",
          province: "上海",
          city: "普陀区",
          address: "上海市普陀区金沙江路 1518 弄",
          zip: 200333,
        },
        {
          date: "2016-05-04",
          name: "王小虎",
          province: "上海",
          city: "普陀区",
          address: "上海市普陀区金沙江路 1517 弄",
          zip: 200333,
        },
        {
          date: "2016-05-01",
          name: "王小虎",
          province: "上海",
          city: "普陀区",
          address: "上海市普陀区金沙江路 1519 弄",
          zip: 200333,
        },
        {
          date: "2016-05-03",
          name: "王小虎",
          province: "上海",
          city: "普陀区",
          address: "上海市普陀区金沙江路 1516 弄",
          zip: 200333,
        },
      ],
      // 列的配置化对象,存储配置信息
      showColumn: {
        date: true,
        name: true,
        provinces: true,
        city: true,
        adreess: true,
        zipCode: true,
      },
    };
  },
  mounted() {
    // 发请求得到showColumnInitData的列的名字
    if(localStorage.getItem("columnSet")){
      this.showColumn = JSON.parse(localStorage.getItem("columnSet"))
    }else{
      this.showColumn = {
        date: true,
        name: true,
        provinces: true,
        city: true,
        adreess: true,
        zipCode: true,
      };
    }
  },
  methods: {
    handleClick(row) {
      console.log(row);
    },
    saveColumn() {
      localStorage.setItem("columnSet",JSON.stringify(this.showColumn))
      this.visible = false;
    },
  },
};
</script>

<style lang="postcss" scoped>
/* 控制淡入淡出效果 */
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.3s;
}
.fade-enter,
.fade-leave-to {
  opacity: 0;
}
</style>

问题:
1、可以简单实现,但最好的方法是列的全部字段也通过配置实现;
2、elementUI的popover嵌套在table里使用时,会出现面板的显示bug,例如本文是采用:visible=“visible”,如果按照正常双向绑定v-model:visible=“visible”,则会出现弹窗闪现的现象,弹出后会立马关闭;
现象:
在这里插入图片描述

原因猜想:
v-model:visible=“visible”,会自动触发遮罩层关闭,置visible变为false(watch监听visible,点击弹出按钮时,visible变为true后会立马变为false);
3、如果某一列设置minWidth属性,如果隐藏该列,则popover会出现弹出两个窗口的异常现象,例如“地址”列:
在这里插入图片描述

故可采用dialog来实现:

<template>
  <div id="app">
    <el-table :data="tableData" border style="width: 100%" ref="table">
      <el-table-column
        fixed
        type="index"
        align="center"
        :index="1">
        <template #header>
          <i
            class="el-icon-setting"
            style="font-size: 22px; cursor: pointer"
            @click="visible = true"
          ></i>
        </template>
      </el-table-column>
      <el-table-column
        prop="date"
        label="日期"
        width="150"
        v-if="showColumn.date"
      >
      </el-table-column>
      <el-table-column
        prop="name"
        label="姓名"
        width="120"
        v-if="showColumn.name"
      >
      </el-table-column>
      <el-table-column
        prop="province"
        label="省份"
        width="120"
        v-if="showColumn.provinces"
      >
      </el-table-column>
      <el-table-column
        prop="city"
        label="市区"
        width="120"
        v-if="showColumn.city"
      >
      </el-table-column>
      <el-table-column
        prop="address"
        label="地址"
        minWidth="300"
        v-if="showColumn.adreess"
      >
      </el-table-column>
      <el-table-column
        prop="zip"
        label="邮编"
        width="120"
        v-if="showColumn.zipCode"
      >
      </el-table-column>
      <el-table-column label="操作" fixed="right" width="100" align="center">
        <template #default="scope">
          <el-button @click="handleClick(scope.row)" type="text" size="small"
            >查看</el-button
          >
          <el-button type="text" size="small">编辑</el-button>
        </template>
      </el-table-column>
    </el-table>
    <el-dialog title="字段配置" v-model="visible">
      <transition name="fade">
        <div>
          <div>选择显示字段</div>
          <div>
            <el-checkbox v-model="showColumn.date" disabled>日期</el-checkbox>
            <el-checkbox v-model="showColumn.name">姓名</el-checkbox>
            <el-checkbox v-model="showColumn.provinces">省份</el-checkbox>
            <el-checkbox v-model="showColumn.city">市区</el-checkbox>
            <el-checkbox v-model="showColumn.adreess">地址</el-checkbox>
            <el-checkbox v-model="showColumn.zipCode">邮编</el-checkbox>
          </div>
        </div>
      </transition>
      <template #footer>
        <span class="dialog-footer">
          <el-button @click="visible = false">取 消</el-button>
          <el-button type="primary" @click="saveColumn">确 定</el-button>
        </span>
      </template>
    </el-dialog>
  </div>
</template>

效果:
在这里插入图片描述

  • 9
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 如果 Vue 项目使用了 Element UI 组件库中的 Table 组件打印表格时不显示表格边框线,可以通过在 CSS 中覆盖样式来解决。 可以在项目中新建一个 CSS 文件,如 `print.css`,在该文件中添加如下样式: ``` /* 表格边框 */ table { border-collapse: collapse; border: 1px solid black; } /* 表格内容边框 */ td, th { border: 1px solid black; } ``` 然后在你打印表格的页面的 head 标签内加入 ``` <link rel="stylesheet" type="text/css" href="print.css" media="print"> ``` 如果你使用vue-cli那么也可以在vue.config.js的配置里面加入 ``` chainWebpack: config => { config.plugin("html").tap(args => { args[0].meta.push({name: 'link', content: 'print.css', media: 'print'}); return args; }); } ``` 这样打印出来的表格就会显示出边框了。 ### 回答2: 在VueElementUI中,如果打印表格时不显示表格边框线,可以通过以下几种方法解决: 1. 使用CSS样式控制:可以在打印时为表格设置特定的样式,如下所示: ```css <style> @media print { .el-table { border-collapse: collapse; border: 1px solid #000; } .el-table th, .el-table td { border: 1px solid #000; } } </style> ``` 该样式将在打印时将表格的边框线设置为1像素宽的黑色线条。 将上述代码放在需要打印表格的页面的样式部分,这样在打印时就会显示表格的边框线。 2. 使用ElementUI自带的打印样式:ElementUI提供了一个打印样式,可以直接使用它来显示表格边框线。只需在打印时添加一个`el-table-print`的class,如下所示: ```html <el-table class="el-table-print" :data="tableData" style="width: 100%"> <!-- 表格内容 --> </el-table> ``` 这样在打印时,表格就会显示边框线。 需要注意的是,使用此方法时,不需要手动设置边框样式,ElementUI会自动应用默认的边框样式。 3. 通过打印设置调整:在打印预览页面中,大部分浏览器都提供了打印设置选项,可以在其中选择打印边框。具体操作可以参考浏览器的打印设置说明。 以上就是解决VueElementUI中打印表格显示边框线的几种方法,可以根据实际需求选择其中一种方式来解决该问题。 ### 回答3: 在vue elementUI中,打印表格显示表格边框线的问题,可以通过以下两种方法来解决: 1. 使用自定义样式:可以在打印样式中添加自定义的CSS样式来显示表格的边框线。在打印时,可以通过媒体查询@media print来应用该样式。例如: ```css @media print { .el-table__body::-webkit-scrollbar { display: none; /* 隐藏滚动条 */ } /* 显示表格边框线 */ .el-table__body, .el-table__header-wrapper, .el-table__fixed-header-wrapper { border: 1px solid #000; } .el-table__row { border-bottom: 1px solid #000; } .el-table__row--hover { background-color: #f5f5f5; /* 鼠标悬停行背景色 */ } .el-table__header { border-bottom: 1px solid #000; } } ``` 2. 使用打印插件:可以使用一些专门用于打印的插件来解决该问题,例如`print-js`插件。该插件可以在打印时保持元素的样式,包括表格的边框线。首先,在项目中安装`print-js`插件: ```bash npm install print-js --save ``` 然后,在需要打印的组件中引入`print-js`插件,并在打印按钮的点击事件中调用相应的方法: ```html <template> <div> <el-button @click="printTable">打印表格</el-button> <el-table ref="table"> <!-- table content --> </el-table> </div> </template> <script> import printJS from 'print-js'; export default { methods: { printTable() { const tableElement = this.$refs.table.$el; // 获取表格DOM元素 printJS(tableElement.innerHTML); // 打印表格 } } } </script> ``` 使用上述方法之一,你就可以在打印时显示表格的边框线了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值