Bootstrap-vue:如何使用内置表过滤组件过滤第二组数据?

时间:2019-05-19 16:33:54

标签: vue.js bootstrap-vue

我正在使用VueJS和 Bootstrap-vue的表组件及其过滤选项来过滤表数据。但是,Bootstrap / Table筛选组件似乎只能应用于原始项目数组数据,因此,根据该文档,“当前无法基于虚拟列的自定义呈现来筛选数据”: https://bootstrap-vue.js.org/docs/components/table#filtering

我的情况是,我有一个仅包含用户ID的原始数据数组,但是有另一个包含用户ID和实际名称的数据数组。因此,我想在表中而不是显示用户ID,而是要显示实际名称。我创建了一个自定义的“格式器”回调函数(docs),可以在表中显示名称,但是由于筛选器组件不属于原始数据数组,因此无法对其进行搜索。

有没有其他方法可以解决此问题,因此也可以通过“分配给”列进行过滤器搜索?

My demo code here单击该编辑器中的“ POSTS”链接

<template>
  <div>
    <b-table :items="posts" :fields="fields">
      <!-- A custom formatted column -->
      <template slot="name" slot-scope="data">{{ data.value.userId }}</template>
    </b-table>
  </div>
</template>

<script>
import axios from "axios";
import users from "../assets/users.json";
export default {
  data() {
    return {
      posts: [],
      users: [],
      // key name is the slot name
      fields: [
        { key: "id" },
        { key: "title" },
        { key: "body" },
        { key: "userId", label: "Assigned To", formatter: "assignNames" }
      ]
    };
  },
  created() {
    this.getPosts();
    this.getNames();
  },
  methods: {
    getPosts() {
      axios.get("https://jsonplaceholder.typicode.com/posts").then(resp => {
        this.posts = resp.data;
      });
    },
    getNames() {
      setTimeout(
        () =>
          Promise.resolve(users).then(resp => {
            this.users = resp.data;
          }),
        1234
      );
    },
    assignNames(id) {
      const user = this.users.find(user => user.id === id);
      return user ? `${user.first_name} ${user.last_name}` : "loading...";
    }
  }
};
</script>

1 个答案:

答案 0 :(得分:0)

您需要在帖子和用户之上创建一个数组。准备显示所需的数据总是好事。

计算属性对此很有帮助。

此外,由于用户来自同步json,因此您不需要promise或setTimeout。

<script>
    import axios from "axios";
    import users from "../assets/users.json";
    export default {
        data() {
            return {
                rawPosts: [],
                // key name is the slot name
                fields: [
                    { key: "id" },
                    { key: "title" },
                    { key: "body" },
                    { key: "user", label: "Assigned To" }
                ]
            };
        },
        created() {
            this.loadPosts();
        },
        methods: {
            loadPosts() {
                axios.get("https://jsonplaceholder.typicode.com/posts").then(resp => {
                    this.rawPosts = resp.data;
                });
            },
            userFrom(id) {
                const user = users.data.find(user => user.id === id);
                return user && `${user.first_name} ${user.last_name}`;
            }
        },
        computed:{
            posts(){
                if(this.rawPosts.length && users.length){
                    return this.rawPosts.map(rawPost => ({...rawPost, user: this.userFrom(rawPost.userId)}));
                }else{
                    //loading case
                }
            }
        }
    };
</script>