Rumah > Soal Jawab > teks badan
Saya mempunyai masalah, apabila bertukar antara komponen menggunakan router.push, pemberitahuan Toast tidak ditunjukkan. Saya mempunyai paparan edit pengguna dan perkara yang saya mahu lakukan ialah mengubah hala ke profil pengguna selepas mengedit dan menunjukkan pemberitahuan roti bakar dengan serta-merta.
Secara kasar, saya mempunyai perkara berikut:
Routes.js
import { createRouter, createWebHistory } from 'vue-router'; //Modules import DashboardIndex from './components/modules/dashboard'; //Users import UsersIndex from './components/modules/users'; import UsersCreate from './components/modules/users/create'; import UsersEdit from './components/modules/users/edit'; import UsersView from './components/modules/users/view'; export default new createRouter({ history: createWebHistory(), routes: [ { path: '/', name: 'dashboard.index', component: DashboardIndex }, { path: '/users', name: 'users.index', component: UsersIndex}, { path: '/user/create', name: 'user.create', component: UsersCreate}, { path: '/user/edit/:id', name: 'user.edit', props: true, component: UsersEdit}, { path: '/user/:id', name: 'user.view', props: true, component: UsersView}, ] })
Boleh digabungkan/pengguna.js
import axios from 'axios'; import { useRouter } from 'vue-router' import { useToast } from 'primevue/usetoast'; export default function useUsers() { const users = ref([]) const user = ref([]) const errors = ref([]) const router = useRouter() const toast = useToast() /** * * All Users * */ const getUsers = async () => { const response = await axios.get('/admin/users') users.value = response.data } /** * * Create User * */ const storeUser = async (data) => { try { let response = await axios.post('/admin/user', data) await router.push({ name: 'user.view', params: { id: response.data.id } }) } catch (e) { if (e.response.status === 422) { errors.value = e.response.data.errors } } } /** * * Create User * */ const updateUser = async (id) => { try { //this.showToast = true; let response = await axios.put(`/admin/user/${id}`, user.value) router.push({ name: 'user.view', params: { id: response.data.id } }) toast.add({severity:'success', summary: 'Éxito', detail: 'El Usuario ha sido modificado', life: 3000}) } catch (e) { if (e.response.status === 422) { errors.value = e.response.data.errors } } } /** * * View User * */ const showUser = async (id) => { let response = await axios.get(`/admin/user/${id}`) user.value = response.data } /** * * Delete User * */ const destroyUser = async (id) => { await axios.delete(`/admin/user/${id}`) } return {errors, users, user, getUsers, storeUser, updateUser, showUser, destroyUser} }
View.vue
<template> <div class="container-fluid"> <Toast position="bottom-right"/> USER PROFILE </div> </template> <script> import useUsers from '../../../composables/users' import { onMounted } from 'vue'; export default { props: { id: { required: true } }, setup(props) { const { user, showUser } = useUsers(); const showUserMounted = async () => { await showUser(props.id) } onMounted(showUserMounted) return { user } } } </script>
Fakta penting, saya menggunakan Prime VUE.
Juga, saya mengulas bahawa apabila saya pergi ke toast.add({severity:'success', Summary: 'Success',detail: 'The User has been Modified', life: 3000}) in showUser, Can display toast mesej dengan baik.
Saya rasa apa yang saya perlukan ialah bendera yang mengubah nilai dalam kaedah updateUser (cth. showToast = true) dan daripada kaedah showUser sahkan sama ada ia benar dan jika ya laksanakan toast.add tetapi saya tidak 'In akhirnya saya tak tahu nak buat apa.
Terima kasih banyak-banyak.
P粉9261742882024-01-17 09:26:09
Dengan pinia untuk makluman kedai, anda mempunyai akses kepada makluman merentas apl:
import { defineStore } from "pinia"; import { useToast } from "primevue/usetoast"; export const useAlertStore = defineStore({ id: "alert", state: () => ({ toast: useToast(), }), actions: { success(title, message) { this.toast.add({ severity: "success", summary: title, detail: message, life: 3000, }); }, info(title, message) { this.toast.add({ severity: "info", summary: title, detail: message, life: 3000, }); }, warn(title, message) { this.toast.add({ severity: "warn", summary: title, detail: message, life: 3000, }); }, error(title, message) { this.toast.add({ severity: "error", summary: title, detail: message, life: 3000, }); }, }, });
Kemudian sebagai contoh fungsi log masuk saya:
const alert = useAlertStore(); async function login() { const authStore = useAuthStore(); await authStore.login(formData.email, formData.password); alert.success( t("alerts.loginTitle"), t("alerts.user") + `${authStore.user.name} ` + t("alerts.loginMessage") ); }
Akhir sekali tambahkan komponen Toast pada fail App.vue anda:
<template> <Toast /> <router-view /> </template>