如何在Bootstrap Vue表格中动态添加列

11
我正在使用Bootstrap Vue,希望能够动态添加列或仅在数据满足某些条件时显示该列。我正在尝试理解作用域插槽,并确定是否应该使用格式化回调函数来实现这一点。理想情况下,如果数据中有“版本2”,我希望只添加一列“版本2”。我不确定从哪里开始。
代码:
    <b-table striped responsive hover :items="episodes" :fields="fields" :filter="filter">
           <template v-slot:cell(version_1)="data">
        <a :href="`${data.value.replace(/[^a-z]-/i,'-').toLowerCase()}`">Definition</a>
      </template>

    </b-table>
</template>
<script>
data() {

    return {
      fields: [{
          key: 'category',
          sortable: true
        },
        {
          key: 'episode_name',
          sortable: true
        },
        {
          key: 'episode_acronym',
          sortable: true
        },
        {
          key: 'version_1',
          sortable: true
        }
      ],
      episodes: [],
      versions: [],
    }

  },   
mounted() {
    return Promise.all([
        // fetch the owner of the blog
        client.getEntries({
          content_type: 'entryEpisodeDefinitions',
          select: 'fields.title,fields.category,fields.slug,fields.episodeAcronym,fields.version,sys.id'
        })

      ])
        .then(response => {
        // console.info(response[0].items);
        return response[0].items
      })
      .then((response) => {

        this.episodes = response.reduce(function( result, item){
          if ( item.fields.version === 1 ) {
          return result.concat({
            category: item.fields.category,
            episode_name: item.fields.title,
            episode_acronym: item.fields.episodeAcronym,
            version_1: 'episodes/' + item.fields.slug + '/' + item.sys.id,
          })
          }
          return result
        }, [])

        this.versions = response.reduce(function( result, item){
          if ( item.fields.version === 2 ) {
          return result.concat({
            version_2: 'episodes/' + item.fields.slug + '/' + item.sys.id,
          })
          }
          return result
        }, [])

        console.info(response);
      })
      .catch(console.error)


  },
</script>

虽然不值得一整篇回答,但请阅读文档 - Caleb Anthony
只是为了澄清。例如,如果没有任何数据有version_2,您想隐藏version_2列。 - Evan
使用计算属性来过滤传递给<b-table>fields定义数组中的字段。未在fields数组中出现的字段将不会显示。 - Troy Morehouse
@Evan 是的,正确的。 - Shawn
1个回答

11

我认为这是您正在寻找的东西:

<b-table :items="items" :fields="fields">
    <template v-for="field in dynamicFields" v-slot:[`cell(${field.key})`]="{ item }">
</b-table>

在脚本中:

this.dynamicFields.push({key: 'someTestKey', label: 'Dynamic Label'})

是的,这正是我在寻找的,我能够按照这个思路实现一些东西。谢谢。 - Shawn

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接