vue3+ts,可缓存的表格展示字段配置,有customRender时

需求背景

需求:页面表格的展示字段可配置。用户修改配置后,下次再进入按照个人定义配置展示。

完成样式
点击按钮,然后设置。
在这里插入图片描述
在这里插入图片描述
其实是类似 AntDesign 的 ProTable - 高级表格 ProTable - 高级表格
但是这里的列展示不能保存设置,刷新会重置。
在这里插入图片描述
现在自己写了个列设置,使用 localStorage 缓存设置。
因为原来的列展示有customRender,localStorage不能直接存方法 customRender,所以先标记,展示的时候再遍历 - findCustomRender。
(其实也可以在 localStorage 缓存每个列的列名,展示的时候遍历原列表取columns值)

实现代码如下

在 template 放个按钮,点击弹出弹窗;
a-table 设置 :columns=“filteredColumns”

<template>
  <a-table
     :columns="filteredColumns"
     rowKey="id"
     :dataSource="tableList.value"
   >

  <a-modal
    title="列设置"
    v-model:visible="isModalVisible"
    @ok="handleOk"
    @cancel="handleCancel"
  >
    <div class="checkbox-container">
      <a-checkbox
        v-model:checked="checkAll"
        class="checkbox-container-top"
        @change="onCheckAllChange"
      >
        全选
      </a-checkbox>
      <a-divider class="divider" />
      <a-checkbox-group
        v-model:value="selectedColumns"
        class="checkbox-container-bottom"
        :options="allColumnsOptions"
        @change="changeCheckBox"
      ></a-checkbox-group>
    </div>
  </a-modal>
  
</template>
<script lang="ts" setup>
// customRender 列展示文字
 const statusMap = {
   0: "未确认",
   1: "已确认",
   3: "已归档",
   4: "已作废",
 };
// 定义表格 Columns列的类型,假设是这样,customRender是 string类型
interface ColumnType {
  title: string;
  dataIndex: string;
  fixed?: "left" | "right";
  width?: number;
  ellipsis?: boolean;
  customRender?: (params: { text: string }) => string;
}
// 列设置- allColumns 是表格Columns值, 例子:
const allColumns: ColumnType[] =[
  {
    title: "ID",
    dataIndex: "id",
    fixed: "left",
    width: 70,
  },
  {
    title: "状态",
    dataIndex: "status",
    width: 80,
    customRender: ({ text }: { text: string }) => statusMap[text],
  }]

const allColumnsOptions = ref(
  allColumns.map((item: { title: string; dataIndex: string }) => ({
    label: item.title,
    value: item.dataIndex,
  })),
);

const localStorageColumns = localStorage.getItem("saveColmuns")
const filteredColumns = ref<ColumnType[]>([]);

const selectedColumns = ref(
  filteredColumns.value.map(
    (col: { dataIndex: string | number }) => col.dataIndex,
  ),
);
const checkAll = ref(true);

// 列设置- 控制弹框的显示与隐藏
const isModalVisible = ref(false);
const showModal = () => {
  isModalVisible.value = true;
  selectedColumns.value = filteredColumns.value.map(
    (col: { dataIndex: string }) => col.dataIndex,
  );
  checkAll.value =
    selectedColumns.value.length === allColumns.length ? true : false;
};
const DeepStringToArray = (array: ColumnType[]) => {
  return array.map((item) => ({
    ...item,
    customRender: item.customRender ? true : undefined,
  }));
};
const findCustomRender = (array: ColumnType[]) => {
  return array.map((item) => {
    if (item.customRender) {
      item.customRender = allColumns.find(
        (c) => item.dataIndex === c.dataIndex,
      )?.customRender;
    }
    return item;
  });
};
const handleOk = () => {
  isModalVisible.value = false;
  filteredColumns.value = allColumns.filter((col: { dataIndex: string }) =>
    selectedColumns.value.includes(col.dataIndex),
  );
  const stringifyColumns = JSON.stringify(
    DeepStringToArray(filteredColumns.value), // localStorage不能直接存方法 customRender,所以先做个标记 customRender:true
  );

  localStorage.setItem("saveColmuns", stringifyColumns)
   
};
const handleCancel = () => {
  isModalVisible.value = false;
};

const onCheckAllChange = (e: { target: { checked: boolean } }) => {
  checkAll.value = e?.target?.checked;
  selectedColumns.value = checkAll.value
    ? allColumns.map((col: { dataIndex: string }) => col.dataIndex)
    : [];
};

const changeCheckBox = (val: CheckboxValueType[]) => {
  checkAll.value = val.length === allColumns.length ? true : false;
};
</script>
<style scoped lang="less">
// 列设置
.checkbox-container {
  display: flex;
  flex-direction: column;
  max-height: 400px;
  overflow: hidden;
  .checkbox-container-top {
    flex-shrink: 0;
  }
  .divider {
    margin: 12px 0;
  }
  .checkbox-container-bottom {
    display: flex;
    flex: 1;
    overflow-y: auto;
    flex-direction: column;
  }
}

.checkbox-item {
  margin-bottom: 10px;
}
</style>
  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 1. 首先,需要在项目中安装Vue3、TypeScript和ElementUI。 2. 在Vue组件中引入ElementUI的Table组件,并定义表格的数据源和列信息。 3. 在Vue组件中定义表格的属性,包括表格的高度、是否显示边框、是否显示分页等。 4. 在Vue组件中定义表格的方法,包括数据的加载、分页、排序等。 5. 在Vue组件中使用Table组件,并将数据源、列信息、属性和方法传递给Table组件。 6. 最后,可以在Vue组件中添加其他的功能,比如搜索、筛选、导出等。 以下是一个简单的示例代码: ``` <template> <el-table :data="tableData" :height="tableHeight" :border="tableBorder" :pagination="tablePagination" @sort-change="handleSortChange" > <el-table-column prop="name" label="姓名" sortable ></el-table-column> <el-table-column prop="age" label="年龄" sortable ></el-table-column> <el-table-column prop="gender" label="性别" sortable ></el-table-column> </el-table> </template> <script lang="ts"> import { defineComponent, ref } from 'vue'; import { ElTable, ElTableColumn } from 'element-plus'; export default defineComponent({ name: 'MyTable', components: { ElTable, ElTableColumn, }, data() { return { tableData: [ { name: '张三', age: 20, gender: '男' }, { name: '李四', age: 25, gender: '女' }, { name: '王五', age: 30, gender: '男' }, ], tableHeight: '500px', tableBorder: true, tablePagination: { pageSize: 10, layout: 'total, sizes, prev, pager, next, jumper', }, }; }, methods: { handleSortChange(sort: { prop: string; order: string }) { console.log(sort); }, }, }); </script> ``` ### 回答2: Vue3是一款流行的JavaScript框架,结合了TypeScript和ElementUI,可以很方便地创建表格组件。 首先,需要在项目中安装Vue3和ElementUI。可以使用Vue CLI命令行工具快速创建一个Vue3项目,并通过npm安装ElementUI依赖。 接下来,在Vue组件中导入所需的库,并使用Vue的`defineComponent`函数创建一个表格组件。可以使用ElementUI的`el-table`和`el-table-column`组件来实现表格的创建和列的定义。 ```typescript <template> <el-table :data="tableData"> <el-table-column v-for="column in tableColumns" :label="column.label" :key="column.prop" :prop="column.prop"> </el-table-column> </el-table> </template> <script lang="ts"> import { defineComponent } from 'vue'; import { ElTable, ElTableColumn } from 'element-plus'; export default defineComponent({ name: 'MyTable', components: { ElTable, ElTableColumn }, data() { return { tableData: [ // 表格数据 { id: 1, name: '张三', age: 18 }, { id: 2, name: '李四', age: 20 }, ], tableColumns: [ // 表格配置 { label: 'ID', prop: 'id' }, { label: '姓名', prop: 'name' }, { label: '年龄', prop: 'age' }, ], }; }, }); </script> ``` 上述代码中,使用了`el-table`和`el-table-column`组件来创建表格表格列。`tableData`中存储了表格的数据,通过`v-for`指令遍历`tableColumns`数组来动态创建每一列。每个列的`label`属性用于显示列名,`prop`属性表示表格数据对象中对应的属性。 最后,在需要使用表格组件的地方引入`MyTable`组件,并将其放置在合适的位置即可。 总结来说,创建一个Vue3 TypeScript的ElementUI表格,需要导入必要的库,定义一个组件,配置表格的数据和列,最后在需要的地方使用该组件即可。 ### 回答3: Vue3是一种现代化的JavaScript框架,它提供了一种简单、灵活的方式来构建用户界面。而TypeScript是一种类型安全的JavaScript超集,它为我们提供了更强大的开发工具和静态类型检查。 Element UI是一套基于Vue的组件库,它提供了许多易于使用和美观的UI组件,能够加速我们的开发效率。在Vue3中使用TypeScript结合Element UI来构建表格,可以让我们更方便地实现数据表格展示和交互。 首先,我们需要安装Vue3和Element UI的依赖。可以通过npm或yarn来进行安装。接着,在main.ts文件中导入Vue、ElementUI和相关组件。在Vue实例的创建过程中,需要使用use方法来引入ElementUI插件。 然后,在组件中定义表格数据和表格列的相关属性。可以使用ref来声明响应式的数据,同使用defineComponent来定义组件。 在template模板中,使用el-table组件来展示表格。可以通过设置data属性来绑定表格数据,通过设置columns属性来定义表格的列。 在script区域,编写逻辑处理代码。可以使用computed属性来派生表格数据,并使用methods属性来定义一些处理函数,比如排序、搜索等。 最后,在style中添加样式,美化表格的显示效果。 总结来说,使用Vue3结合TypeScript和Element UI可以很方便地实现一个数据表格,只需要引入相关依赖和组件,定义数据和列属性,编写逻辑处理代码,最后美化表格的样式。这样我们就可以通过简单的代码实现一个功能完善的表格,并且在开发过程中更加易于维护和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值