现在我正在使用Vuetify.
当然,UI组件已经足够方便地包装.但是,我想重用一些带有自定义选项的组件.
特别是,我想重用数据表组件.
https://vuetifyjs.com/ja/components/data-tables
如果所有视图都具有完全相同的标题和数据,则没有问题.当每个视图具有不同的数据时,它不起作用.
这是我的代码:
Wrapper.vue
<template>
<v-card>
<v-card-title>
<span class="pr-3">{{ tableTitle }}</span>
<slot name="actions"/>
<v-spacer/>
<v-text-field
append-icon="search"
label="search"
single-line
hide-details
v-model="search"
/>
</v-card-title>
<v-data-table
:search="search"
:headers="headers"
:items="items"
hide-actions
>
<!-- problem is here! -->
<slot name="items" slot="items" slot-scope="props"></slot>
<template slot="expand" slot-scope="props">
<v-card flat>
<v-card-text>{{ props.item.note }}</v-card-text>
</v-card>
</template>
<template slot="no-data">
<v-alert :value="true" color="error" icon="warning">
no data.
</v-alert>
</template>
<template slot="no-results">
<v-alert :value="true" color="error" icon="warning">
no result.
</v-alert>
</template>
</v-data-table>
</v-card>
</template>
<script>
export default {
props: {
tableTitle: {type: String},
search: {type: String},
headers: {type: Array},
items: {type: Array}
}
}
</script>
Run Code Online (Sandbox Code Playgroud)
Main.vue
<template>
<v-layout fluid fill-height justify-center align-center row wrap>
<v-flex sm12 md12 fill-height>
<main-custom-table
tableTitle="table1"
:headers="headers"
:items="items"
>
<template slot="actions">
<v-btn color="info">
<v-icon>add</v-icon>
add
</v-btn>
</template>
<!-- problem is here! -->
<template slot="items">
<tr>
<td class="text-xs-left">{{ items.id }}</td>
<td class="text-xs-left">{{ items.data1 }}</td>
<td class="text-xs-left">{{ items.data2 }}</td>
<td class="justify-center">
<v-btn icon class="mx-0" @click="">
<v-icon color="teal">edit</v-icon>
</v-btn>
</td>
</tr>
</template>
</main-custom-table>
</v-flex>
</v-layout>
</template>
<script>
export default {
name: "main",
data() {
return {
dialog: false,
search: '',
headers: [
{text: 'ID', value: 'id'},
{text: 'DATA1', value: 'data1'},
{text: 'DATA2', value: 'data2'}
],
items: [
{
'id': 1,
'data1': 10,
'data2': 12,
'note': aaaaaa
},
{
'id': 2,
'data1': 20,
'data2': 13,
'note': bbbbbb
},
{
'id': 5,
'data1': 30,
'data2': 14,
'note': cccccc
}
]
};
}
}
</script>
Run Code Online (Sandbox Code Playgroud)
我想只在Main.vue(和其他视图)中编写tbody,在Wrapper.vue中编写其他可选元素.
谢谢您的帮助.
小智 0
它不起作用,因为您的插槽范围的使用不正确。下面的改变应该有效。
包装器.vue
<v-data-table
:search="search"
:headers="headers"
:items="items"
hide-actions
>
<!-- problem is here! -->
<slot name="items" v-bind:item="props" slot-scope="props"></slot>
<template slot="expand" slot-scope="props">
<v-card flat>
<v-card-text>{{ props.item.note }}</v-card-text>
</v-card>
</template>
<template slot="no-data">
<v-alert :value="true" color="error" icon="warning">
no data.
</v-alert>
</template>
<template slot="no-results">
<v-alert :value="true" color="error" icon="warning">
no result.
</v-alert>
</template>
</v-data-table>
Run Code Online (Sandbox Code Playgroud)
主视图
<template slot="items" slot-scope="item">
<tr>
<td class="text-xs-left">{{ item.id }}</td>
<td class="text-xs-left">{{ item.data1 }}</td>
<td class="text-xs-left">{{ item.data2 }}</td>
<td class="justify-center">
<v-btn icon class="mx-0" @click="">
<v-icon color="teal">edit</v-icon>
</v-btn>
</td>
</tr>
</template>
Run Code Online (Sandbox Code Playgroud)
有关更多信息,请参阅:https://v2.vuejs.org/v2/guide/components-slots.html#Scoped-Slots-with-the-slot-scope-Attribute