如何在数组数组中的 vue table 中显示数据
How to show data in vue table that is in an array of arrays
我正在尝试在 vue table 中显示从服务接收到的数据,但数据的形式很复杂。服务器 returns 数组的数组。所以在 vue 中显示它们有点困难 table.
这是我得到的回复
vue的字段定义table
`
export const FieldsDef_doctor_schedule = [
{
name:'doctor_id',
title: 'doctor ID',
sortField: 'id',
callback: 'scheduleId'
},
{
name:'department',
title: 'Department',
sortField: 'department'
},
{
name:'date',
title:'Available Time',
callback:'schedueleCall'
},
{
name: '__slot:actions',
title: 'Actions',
dataClass: 'center aligned'
}
]
`
Vue Table
由于日期时间信息分别对应doctor_id
和department
。我希望 vue table 根据医生 ID departmrnt.
在一行中显示 3 个名为 date_time
的数组
演示
有人可以帮忙吗?
模板代码
<template>
<div id="schedule">
<div class="page-wrapper">
<div class="container" style="margin-top: 25px;margin-left: 50px;">
<div class="row">
<div class="col-md-7">
<h4 class="page-title">Schedule</h4>
</div>
<div class="col-md-4 text-right m-b-20">
<router-link class="ui button positive" to="/admin/doctors_schedule/addschedule">
<i class="plus icon"></i>
<strong>
Add
Schedule
</strong>
</router-link>
</div>
</div>
<div class="row">
<div class="col-md-11">
<hr />
</div>
</div>
<div class="row">
<div class="col-md-11 border">
<div class="ui container">
<filter-bar></filter-bar>
<vuetable
ref="vuetable"
api-url="https://vuetable.ratiw.net/api/users"
:fields="fields"
pagination-path
:per-page="5"
:multi-sort="true"
:sort-order="sortOrder"
:append-params="moreParams"
@vuetable:pagination-data="onPaginationData"
>
<template slot="actions" slot-scope="props">
<div class="custom-actions">
<router-link to="/admin/doctors_schedule/editschedule" class="ui button yellow">
<i class="edit icon"></i>
</router-link>
<button
class="ui button red"
@click="onAction('delete-item', props.rowData,
props.rowIndex)"
>
<i class="trash alternate icon"></i>
</button>
</div>
</template>
</vuetable>
<div class="vuetable-pagination ui basic segment grid">
<vuetable-pagination-info ref="paginationInfo"></vuetable-pagination-info>
<vuetable-pagination
ref="pagination"
@vuetable-pagination:change-page="onChangePage"
></vuetable-pagination>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
import Vue from "vue";
import VueEvents from "vue-events";
import Vuetable from "vuetable-2/src/components/Vuetable";
import VuetablePagination from "vuetable-2/src/components/VuetablePagination";
import VuetablePaginationInfo from "vuetable-2/src/components/VuetablePaginationInfo";
import FilterBar from "@/components/Pages/Admin/import_details/FilterBar";
import { FieldsDef_doctor_schedule } from "@/components/Pages/Admin/import_details/FieldsDef_doctor_schedule";
import { apiDomain } from "@/components/Pages/Authentication/config";
Vue.use(VueEvents);
Vue.component("filter-bar", FilterBar);
export default {
components: {
Vuetable,
VuetablePagination,
VuetablePaginationInfo
},
data() {
return {
fields: FieldsDef_doctor_schedule,
sortOrder: [],
moreParams: {},
apiURL: ""
};
},
mounted() {
this.$events.$on("filter-set", eventData => this.onFilterSet(eventData));
this.$events.$on("filter-reset", e => this.onFilterReset());
},
methods: {
scheduleId(value) {
return value;
console.log(value);
},
onPaginationData(paginationData) {
this.$refs.pagination.setPaginationData(paginationData);
this.$refs.paginationInfo.setPaginationData(paginationData);
},
onChangePage(page) {
this.$refs.vuetable.changePage(page);
},
onAction(action, data, index) {
console.log("slot action: " + action, data.name, index);
},
onFilterSet(filterText) {
this.moreParams.filter = filterText;
Vue.nextTick(() => this.$refs.vuetable.refresh());
},
onFilterReset() {
delete this.moreParams.filter;
Vue.nextTick(() => this.$refs.vuetable.refresh());
}
},
created() {
this.apiURL = apiDomain + "api/getDoctorScheduleInfo";
this.$http
.get(this.apiURL)
.then(response => {
// console.log(response.body.scheduleInfo)
console.log(response);
response.body.scheduleInfo.forEach(function(val) {
// console.log(val.date_time)
val.date_time.forEach(function(val2) {
console.log(
"Date: " +
val2.date +
", Time: " +
val2.time_from +
" To " +
val2.time_to
);
});
});
})
.catch(e => {
console.log(e);
});
}
};
</script>
我注意到的几件事...
您缺少 data-path
属性,您需要它,因为您的数据在 sheduleInfo
变量中
即:data-path="sheduleInfo"
...但是,您还可以使用 transform
属性 到 handle/transform 的数据。因为您想遍历内容,所以这并不能(单独)解决多条目问题。
向模板添加额外的插槽并更新配置(更新日期字段以改为使用 __slot:availableTimes
)
<template slot="availableTimes" slot-scope="props">
<div v-for="(dt, i)props.rowData.date_time" :key="i">
Date {{dt.date}} ...etc
</div>
</template>
我正在尝试在 vue table 中显示从服务接收到的数据,但数据的形式很复杂。服务器 returns 数组的数组。所以在 vue 中显示它们有点困难 table.
这是我得到的回复
vue的字段定义table
`
export const FieldsDef_doctor_schedule = [
{
name:'doctor_id',
title: 'doctor ID',
sortField: 'id',
callback: 'scheduleId'
},
{
name:'department',
title: 'Department',
sortField: 'department'
},
{
name:'date',
title:'Available Time',
callback:'schedueleCall'
},
{
name: '__slot:actions',
title: 'Actions',
dataClass: 'center aligned'
}
]
`
Vue Table
由于日期时间信息分别对应doctor_id
和department
。我希望 vue table 根据医生 ID departmrnt.
date_time
的数组
演示
有人可以帮忙吗?
模板代码
<template>
<div id="schedule">
<div class="page-wrapper">
<div class="container" style="margin-top: 25px;margin-left: 50px;">
<div class="row">
<div class="col-md-7">
<h4 class="page-title">Schedule</h4>
</div>
<div class="col-md-4 text-right m-b-20">
<router-link class="ui button positive" to="/admin/doctors_schedule/addschedule">
<i class="plus icon"></i>
<strong>
Add
Schedule
</strong>
</router-link>
</div>
</div>
<div class="row">
<div class="col-md-11">
<hr />
</div>
</div>
<div class="row">
<div class="col-md-11 border">
<div class="ui container">
<filter-bar></filter-bar>
<vuetable
ref="vuetable"
api-url="https://vuetable.ratiw.net/api/users"
:fields="fields"
pagination-path
:per-page="5"
:multi-sort="true"
:sort-order="sortOrder"
:append-params="moreParams"
@vuetable:pagination-data="onPaginationData"
>
<template slot="actions" slot-scope="props">
<div class="custom-actions">
<router-link to="/admin/doctors_schedule/editschedule" class="ui button yellow">
<i class="edit icon"></i>
</router-link>
<button
class="ui button red"
@click="onAction('delete-item', props.rowData,
props.rowIndex)"
>
<i class="trash alternate icon"></i>
</button>
</div>
</template>
</vuetable>
<div class="vuetable-pagination ui basic segment grid">
<vuetable-pagination-info ref="paginationInfo"></vuetable-pagination-info>
<vuetable-pagination
ref="pagination"
@vuetable-pagination:change-page="onChangePage"
></vuetable-pagination>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</template>
<script>
import Vue from "vue";
import VueEvents from "vue-events";
import Vuetable from "vuetable-2/src/components/Vuetable";
import VuetablePagination from "vuetable-2/src/components/VuetablePagination";
import VuetablePaginationInfo from "vuetable-2/src/components/VuetablePaginationInfo";
import FilterBar from "@/components/Pages/Admin/import_details/FilterBar";
import { FieldsDef_doctor_schedule } from "@/components/Pages/Admin/import_details/FieldsDef_doctor_schedule";
import { apiDomain } from "@/components/Pages/Authentication/config";
Vue.use(VueEvents);
Vue.component("filter-bar", FilterBar);
export default {
components: {
Vuetable,
VuetablePagination,
VuetablePaginationInfo
},
data() {
return {
fields: FieldsDef_doctor_schedule,
sortOrder: [],
moreParams: {},
apiURL: ""
};
},
mounted() {
this.$events.$on("filter-set", eventData => this.onFilterSet(eventData));
this.$events.$on("filter-reset", e => this.onFilterReset());
},
methods: {
scheduleId(value) {
return value;
console.log(value);
},
onPaginationData(paginationData) {
this.$refs.pagination.setPaginationData(paginationData);
this.$refs.paginationInfo.setPaginationData(paginationData);
},
onChangePage(page) {
this.$refs.vuetable.changePage(page);
},
onAction(action, data, index) {
console.log("slot action: " + action, data.name, index);
},
onFilterSet(filterText) {
this.moreParams.filter = filterText;
Vue.nextTick(() => this.$refs.vuetable.refresh());
},
onFilterReset() {
delete this.moreParams.filter;
Vue.nextTick(() => this.$refs.vuetable.refresh());
}
},
created() {
this.apiURL = apiDomain + "api/getDoctorScheduleInfo";
this.$http
.get(this.apiURL)
.then(response => {
// console.log(response.body.scheduleInfo)
console.log(response);
response.body.scheduleInfo.forEach(function(val) {
// console.log(val.date_time)
val.date_time.forEach(function(val2) {
console.log(
"Date: " +
val2.date +
", Time: " +
val2.time_from +
" To " +
val2.time_to
);
});
});
})
.catch(e => {
console.log(e);
});
}
};
</script>
我注意到的几件事...
您缺少
data-path
属性,您需要它,因为您的数据在sheduleInfo
变量中
即:data-path="sheduleInfo"
...但是,您还可以使用
transform
属性 到 handle/transform 的数据。因为您想遍历内容,所以这并不能(单独)解决多条目问题。向模板添加额外的插槽并更新配置(更新日期字段以改为使用
__slot:availableTimes
)
<template slot="availableTimes" slot-scope="props">
<div v-for="(dt, i)props.rowData.date_time" :key="i">
Date {{dt.date}} ...etc
</div>
</template>