Vuetify ne peut pas charger la valeur par défaut dans Vue-Toastification
<p>Ce que j'ai essayé, c'est vue-toastification en utilisant un composant personnalisé et certains composants Vuetify dans toast. J'ai créé le référentiel en utilisant <code>npm create vuetify@latest</code> et installé la bibliothèque <code>npm i vue-toastification@latest</code>. Ensuite, j'ai utilisé le plug-in : </p>
<pre class="lang-js Prettyprint-override"><code>// main.ts
//Grillage
importer Toast, { POSITION } depuis "vue-toastification" ;
importer "vue-toastification/dist/index.css" ;
const app = createApp(App);
options const = {
shareAppContext : true, // Depuis https://github.com/Maronato/vue-toastification#access-global-components-and-plugins-inside-toasts
position : POSITION.BOTTOM_CENTER,
} ;
registrePlugins(application);
app.use(Toast, options);
</code></pre>
<p>Ensuite, j'ai essayé d'appeler toast en utilisant le code suivant : </p>
<pre class="lang-js Prettyprint-override"><code>// store/error.ts
importer { useToast } depuis "vue-toastification" ;
importer MyComponent depuis "@/components/MyComponent.vue" ;
const toast = useToast();
export const useErrorStore = definitionStore("erreur", () => {
fonction locationErreur() {
toast(MonComposant);
}
});
</code></pre>
<p>Dans mon composant : </p>
<pre class="lang-js Prettyprint-override"><code>// composants/MyComponent.vue
<modèle>
<div class="conteneur">
<v-conteneur>
<v-rangée>
<v-col> Exemple d'alerte </v-col>
<v-col>
<v-btn @click="recharger">Recharger</v-btn>
</v-col>
</v-rangée>
</v-conteneur>
</div>
</modèle>
<configuration du script lang="ts">
fonction recharger() {
if (type de fenêtre !== "non défini") {
window.location.reload();
}
}
</script>
</code></pre>
<p>我从App.vue文件中调用它:</p>
<pre class="lang-js Prettyprint-override"><code>// App.vue
<modèle>
<v-app>
<v-main>
<v-btn @click="loc">Erreur de localisation</v-btn>
</v-main>
</v-app>
</modèle>
<configuration du script lang="ts">
importer { useErrorStore } depuis "./store/error";
const errorStore = useErrorStore();
fonction loc() {
errorStore.locationError();
}
</script>
</code></pre>
<p>
<pre class="brush:php;toolbar:false;">[Vue warn] : injection "Symbol(vuetify:defaults)" pas trouvé.
à <VContainer>
at <MyComponent key=1 toast-id=0 onCloseToast=fn<bound closeToast> >
à <VtToast key="_default00" position = "en bas au centre" draggable=true ... >
à <TransitionGroup tag="div" enter-active-class="Vue-Toastification__bounce-enter-active" move-class="Vue-Toastification__bounce-move" ...>
à <VtTransition transition="Vue-Toastification__bounce" class = "Vue-Toastification__container en bas au centre" >
at <VueToastification eventBus= EventBus {allHandlers : {…}} shareAppContext= {_uid : 0, _component : {…}, _props : null, _container : div#app, _context : {…}, …} position="bottom -centre" >
[Vue warn] : erreur non gérée lors de l'exécution de la fonction de configuration
à <VContainer>
at <MyComponent key=1 toast-id=0 onCloseToast=fn<bound closeToast> >
à <VtToast key="_default00" position = "en bas au centre" draggable=true ... >
à <TransitionGroup tag="div" enter-active-class="Vue-Toastification__bounce-enter-active" move-class="Vue-Toastification__bounce-move" ...>
à <VtTransition transition="Vue-Toastification__bounce" class = "Vue-Toastification__container en bas au centre" >
at <VueToastification eventBus= EventBus {allHandlers : {…}} shareAppContext= {_uid : 0, _component : {…}, _props : null, _container : div#app, _context : {…}, …}position = "en bas au centre" >
[Vue warn] : erreur non gérée lors de l'exécution du vidage du planificateur. Il s'agit probablement d'un bug interne de Vue. Veuillez ouvrir un numéro sur https://new-issue.vuejs.org/?repo=vuejs/core
à <VContainer>
at <MyComponent key=1 toast-id=0 onCloseToast=fn<bound closeToast> >
à <VtToast key="_default00" position = "en bas au centre" draggable=true ... >
à <TransitionGroup tag="div" enter-active-class="Vue-Toastification__bounce-enter-active" move-class="Vue-Toastification__bounce-move" ...>
à <VtTransition transition="Vue-Toastification__bounce" class = "Vue-Toastification__container en bas au centre" >
at <VueToastification eventBus= EventBus {allHandlers : {…}} shareAppContext= {_uid : 0, _component : {…}, _props : null, _container : div#app, _context : {…}, …} position="bottom -centre" >
Erreur non interceptée (promise) : [Vuetify] Impossible de trouver l'instance par défaut
à injectDefaults (defaults.ts:28:24)
lors de l'installation (defineComponent.tsx:118:24)
à callWithErrorHandling (runtime-core.esm-bundler.js:158:18)
à setupStatefulComponent (runtime-core.esm-bundler.js:7236:25)
à setupComponent (runtime-core.esm-bundler.js:7197:36)
sur mountComponent (runtime-core.esm-bundler.js:5599:7)
à processComponent (runtime-core.esm-bundler.js:5565:9)
au patch (runtime-core.esm-bundler.js:5040:11)
chez mountChildren (runtime-core.esm-bundler.js:5284:7)
à mountElement (runtime-core.esm-bundler.js:5191:7)</pre>
<p>
<p>