我正在使用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>
答案 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>