在vue中使用vuetify数据表动态地显示表列。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在vue中使用vuetify数据表动态地显示表列。相关的知识,希望对你有一定的参考价值。

看着像例子。

如何使用v-select list来显示vuetify数据表的隐藏列

我做了一个非常类似的东西,但由于某些原因,当我改变头数据时,表不会被重新渲染。

https: /codepen.ioMeff1penvYLNYWR

<template>
  <v-container>
    <v-select v-model="value" :items="headers" label="Select Item" multiple return-object>
      <template v-slot:selection="{ item, index }">
        <v-chip v-if="index === 0">
          <span>{{ item.text }}</span>
        </v-chip>
        <span v-if="index === 1">(+{{ value.length - 1 }} others)</span>
      </template>
    </v-select>
    <br />
    <v-data-table :headers="this.selectedHeaders" :items="xyz">
      <template slot="items" slot-scope="props">
        <td
          v-for="header in this.selectedHeaders"
          :key="header"
          v-show="show[header.text]"
        >{{ props.item[header.value] }}</td>
      </template>
    </v-data-table>
  </v-container>
</template>


<script lang="ts">
const charData: Array<object> = [
  {
    id: 10,
    firstName: "Kyle",
    lastName: "Broflovski",
    saying: "Goddamnit Cartman!"
  },
  {
    id: 20,
    firstName: "Eric",
    lastName: "Cartman",
    saying: "Screw you guys, Im going home"
  },
  {
    id: 30,
    firstName: "Stanley",
    lastName: "Marsh",
    saying: "WTF"
  },
  {
    id: 40,
    firstName: "Kenny",
    lastName: "McCormick",
    saying: "hmhpmhphmphmhp"
  }
];

let headers: Array<object> = [];
let selectedHeaders: Array<object> = [];
const show: any = {};
const value: Array<object> = [];
let selectedData: Array<object> = [];

import Vue from "vue";

export default Vue.extend({
  name: "PFTable",
  data: () => ({
    charData,
    headers,
    value,
    selectedHeaders,
    selectedData,
    show
  }),

  computed: {
    xyz: () => {
      return selectedData;
    }
  },

  watch: {
    value(val) {
      selectedHeaders = val;

      const res = selectedHeaders.map(x => x.text);
      selectedData = [];

      for (const k in charData) {
        const element: any = charData[k];

        const filtered = Object.keys(element)
          .filter(key => res.includes(key))
          .reduce((obj: any, key: any) => {
            obj[key] = element[key];
            return obj;
          }, {});

        selectedData.push(filtered);
      }
    }
  },

  beforeCreate() {
    headers = [];
    const headersData = Object.keys(charData[0]);

    headersData.forEach(element => {
      headers.push({ text: element, value: element });
    });

    selectedHeaders = headers;
    selectedData = charData;
  }
});
</script>

我找不到任何方法来显示选择列表中选择的列。

我有一个selectedData数组,它作为它的项目属性被绑定到数据表上。selectedData作为一个计算属性返回,当选择列表发生变化时,它在watcher方法中被改变了。当底层属性发生变化时,计算属性是不是也应该重新评估?

答案

我想你在给你的outa范围的selectedHeaders赋值后,你在你的watcher中松开了对this.selectedHeaders的引用?因此,你的模板从来没有得到任何变化,表现为预期。

更改。

watch: {
   value(val) {
      selectedHeaders = val;

改为

     selectedHeaders.splice(0).push(...val) 

     this.selectedHeaders = val
另一答案

尝试在data()方法中初始化你的数据。

以上是关于在vue中使用vuetify数据表动态地显示表列。的主要内容,如果未能解决你的问题,请参考以下文章

将图标附加到 vuetify 数据表中的表列?

如何使用 vuetify 在 vue 中显示两个数据库表中的数据

如何在我现有的 Vue2 项目中清楚而分开地使用来自 vuetify 的组件

Vue Vuetify 读取动态生成的 v-select 元素的选定选项

如何使用 Vuetify 网格系统循环显示卡片组件?

Vue, Vuetify 2, v-data-table - 如何在表格底部显示总原始数据