Vuetify 全局注入 Snackbar
Vuetify About 1,157 wordsApp.vue
在App.vue
中全局定义v-snackbar
,并且使用provide
对全局提供自己封装的success
、error
方法。
<template>
<v-snackbar
v-model="snackbar"
:color="color"
:timeout="timeout"
:location="location"
>
{{ text }}
</v-snackbar>
<router-view/>
</template>
<script setup>
import {provide, ref, watch} from 'vue';
const snackbar = ref(false);
const color = ref('success');
const text = ref('');
const location = ref('top');
const timeout = ref(2000);
function success(content) {
snackbar.value = true;
color.value = 'success';
text.value = content;
}
function error(content) {
snackbar.value = true;
color.value = 'error';
text.value = content;
}
provide('snackbar', {success, error, location, timeout});
</script>
其他组件中使用
在其他组件中(子组件/孙组件等等都可以),使用inject
注入snackbar
,然后使用success
、error
等提供的方法。
<script setup>
import {inject} from "vue";
const snackbar = inject('snackbar');
function showToast() {
snackbar.success('Account Snackbar');
}
</script>
<template>
<v-container>
<v-btn @click="showToast">
Account
</v-btn>
</v-container>
</template>
Views: 827 · Posted: 2024-02-16
————        END        ————
Give me a Star, Thanks:)
https://github.com/fendoudebb/LiteNote扫描下方二维码关注公众号和小程序↓↓↓
Loading...