el-table-v2修改表头、单元格、表格整体的宽度、高度样式

有关部分的完整代码:

javascript 复制代码
//template里面
 <div style="height: calc(100% - 60px); width: 100%">
      <el-auto-resizer>
        <template #default="{ height, width }">
          <el-table-v2
            v-model:expanded-row-keys="expandedRowKeys"
            :columns="columns"
            :data="changedTableData"
            :width="width"
            :height="height"
            expand-column-key="name"
            row-key="id"
            :header-cell-props="headerClassName"
          >
            <template #cell="{ column, rowData }">
              <template v-if="column.key == 'isConfig'">
                <el-checkbox
                  v-model="changedTableData.isConfig"
                  :disabled="!isEditMode"
                />
              </template>
            </template>
          </el-table-v2>
        </template>
      </el-auto-resizer>
    </div>

//script里面

// 列定义
const columns = [
 
  {
    key: "isConfig",
    dataKey: "isConfig",
    title: "是否为基准配置",
    width: "10%",
    style: {
      backgroundColor: "#fffacd",//-----------使用这个给单元格修改样式
    },
  },
  {
    key: "baseline",
    dataKey: "baseline",
    title: "基准数量",
    width: "10%",
    style: {
      backgroundColor: "#fffacd",
    },
  },
];

//和header-cell-props配合使用,修改某一列的header样式
const headerClassName = ({ column, style }) => {
  if (column.key == "isConfig" || column.key == "baseline") {
    style.backgroundColor = "#fffacd";
  }
};

1.修改某一个表头的样式:header-cell-props和对应的函数配合着使用,函数可以拿到一些参数,具体有什么参数可以查看elementUI的文档

2.修改单元格的样式:

方法一:给el-table-v2表格的单元格设置边框

javascript 复制代码
(第一步)给el-table-v2添加下面这一行,注意冒号也是需要的。
    :cell-props="cellProps"
(第二步)在script中加下面的代码
const cellProps = ({ column }) => {
  return {
    style: {
      borderRight: "1px solid #ebeef5", // 列边框(右侧)
      borderBottom: "1px solid #ebeef5", // 行边框(底部)
    },
  };
};

方法二:直接在列的设置里面添加style,能做到什么样子,我不清楚,但是对于背景颜色的设置是成功了的。

javascript 复制代码
// 列定义
const columns =[{
    key: "isConfig",
    dataKey: "isConfig",
    title: "是否为基准配置",
    width: "10%",
    style: {
      backgroundColor: "#fffacd",
    },
  },
  {
    key: "baseline",
    dataKey: "baseline",
    title: "基准数量",
    width: "10%",
    style: {
      backgroundColor: "#fffacd",
    },]

3.设置整体表格的宽度和高度

关于这个我是想要实现表格占满整个页面,el-table-v2中的width和height只能接受具体的数字,如果写"100%",会报错。我是使用的el-auto-resizer去实现,注意它外面还需要嵌套一层,并给这一层赋上宽度和高度。

javascript 复制代码
 <div style="height: calc(100% - 60px); width: 100%">
      <el-auto-resizer>
        <template #default="{ height, width }">
          <el-table-v2
            v-model:expanded-row-keys="expandedRowKeys"
            :columns="columns"
            :data="changedTableData"
            :width="width"
            :height="height"
            expand-column-key="name"
            row-key="id"
            :header-cell-props="headerClassName"
          >
            <template #cell="{ column, rowData }">
              <template v-if="column.key == 'isConfig'">
                <el-checkbox
                  v-model="changedTableData.isConfig"
                  :disabled="!isEditMode"
                />
              </template>
            </template>
          </el-table-v2>
        </template>
      </el-auto-resizer>
    </div>

希望对你们有用。

相关推荐
努力了吗梁同学几秒前
Nuxt3 中使用 pnpm 安装的 NuxtImg 使用会提示找不到图片
前端·vue·pnpm·nuxt·nuxtimg
归于尽3 分钟前
用火山引擎实现语音生成的实战踩坑与优化
前端·react.js
渐行渐远君489014 分钟前
从手动到自动,React一站式前端国际化解决方案
前端
S侯5 分钟前
状态管理库对比总结
前端·前端框架
武昌库里写JAVA5 分钟前
IDE(集成开发环境),集成阿里云的通义大模型
vue.js·spring boot·毕业设计·layui·课程设计
悠然小熠5 分钟前
解决python环境安装一些包报错:缺少 Microsoft Visual C++ 14.0
前端
旅行中的伊蕾娜9 分钟前
前端实现ios26最新液态玻璃效果!
前端·css3·动画
Turing_01011 分钟前
🤚🏻 Harmony OS Next玩转多层级手势事件:当组件遇上“套娃”,触摸该怎么分家?
前端
前端大卫12 分钟前
localStorage 也能监听变化?带你实现组件和标签页的同步更新!【附完整 Vue/React Hook 源码】
前端·vue.js·react.js
美团技术团队22 分钟前
无需代码!美团 NoCode 像聊天一样轻松搭建你的专属网站
前端