使用 Tailwind
HOC
設計 你可以很輕鬆地製作出一個高階元件(Higher-Order Components)並且依照不同的需求客製元件的內容。
VTailwindModal.vue
<template>
<vue-final-modal
v-slot="{ params, close }"
v-bind="$attrs"
classes="flex justify-center items-center"
content-class="relative flex flex-col max-h-full mx-4 p-4 border dark:border-gray-800 rounded bg-white dark:bg-gray-900"
>
<span class="mr-8 text-2xl font-bold">
<slot name="title"></slot>
</span>
<div class="flex-grow overflow-y-auto">
<slot :params="params"></slot>
</div>
<div class="flex-shrink-0 flex justify-center items-center pt-4">
<v-button class="vfm-btn" @click="$emit('confirm', close)">confirm</v-button>
<v-button class="vfm-btn" @click="$emit('cancel', close)">cancel</v-button>
</div>
<button class="absolute top-0 right-0 mt-2 mr-2" @click="close">
<mdi-close></mdi-close>
</button>
</vue-final-modal>
</template>
<script>
export default {
name: 'VTailwindModal',
inheritAttrs: false,
emits: ['cancel', 'confirm']
}
</script>
如何使用 VTailwindModal
範例
Show code
<template>
<div>
<v-tailwind-modal v-model="show" @confirm="confirm" @cancel="cancel">
<template v-slot:title>Hello, vue-final-modal</template>
<p>Vue Final Modal is a renderless, stackable, detachable and lightweight modal component.</p>
</v-tailwind-modal>
<v-button @click="show = true">Open modal</v-button>
</div>
</template>
<script>
export default {
data: () => ({
show: false
}),
methods: {
confirm() {
// some code...
this.show = false
},
cancel(close) {
// some code...
close()
}
}
}
</script>
客製化 Transition 範例
<template>
<div>
<v-tailwind-modal
v-model="show"
@confirm="confirm"
@cancel="cancel"
:transition="{
'enter-active-class': 'transition duration-200 ease-in-out transform',
'enter-from-class': 'translate-y-full',
'enter-to-class': 'translate-y-0',
'leave-active-class': 'transition duration-200 ease-in-out transform',
'leave-to-class': 'translate-y-full',
'leave-from-class': 'translate-y-0'
}"
>
<template v-slot:title>Hello, vue-final-modal</template>
<p>Vue Final Modal is a renderless, stackable, detachable and lightweight modal component.</p>
</v-tailwind-modal>
<v-button @click="show = true">Open modal</v-button>
</div>
</template>
<script>
export default {
data: () => ({
show: false
}),
methods: {
confirm() {
// some code...
this.show = false
},
cancel(close) {
// some code...
close()
}
}
}
</script>