Tidak pernah mendengar tentang react-toastify sebelum ini? Pergi semak demo
Saya sangat teruja dengan keluaran ini! Fokus utama adalah pada penyesuaian dan matlamat saya adalah untuk memperkasakan anda (dan diri saya sendiri) supaya anda boleh memperibadikan rupa dan rasa untuk pemberitahuan sepenuhnya.
Ringkasnya, react-toastify sepatutnya boleh digabungkan ke dalam mana-mana sistem reka bentuk.
Lembaran gaya kini disuntik secara automatik, jadi anda tidak perlu mengimportnya lagi. Fail CSS masih dieksport oleh pustaka.
import { ToastContainer, toast } from 'react-toastify'; function App(){ const notify = () => toast("Wow so easy !"); return ( <div> <button onClick={notify}>Notify !</button> <ToastContainer /> </div> ); }
Salah satu permintaan teratas ialah cara menyesuaikan pemberitahuan. Untuk bersikap adil, sehingga keluaran ini, ia agak mencabar kerana ia memerlukan pengguna untuk mengatasi banyak kelas CSS.
Saya telah mempermudahkan struktur DOM pemberitahuan dengan mengalih keluar elemen div luar, elemen bersarang, dsb... Ini merupakan perubahan besar yang ketara, tetapi usaha ini benar-benar berbaloi. Saya dengan yakin boleh mengatakan bahawa perpustakaan kini boleh menyepadukan dengan lancar ke dalam mana-mana sistem reka bentuk.
Di bawah, saya telah melaksanakan beberapa reka bentuk berbeza menggunakan Tailwind sahaja. Saya tidak mengatasi satu pun kelas CSS daripada react-toastify ?!
Kepala ke stackblitz untuk menyemak kod.
Bagaimana ia berfungsi dalam amalan? Di sebelah kiri, kami mempunyai struktur DOM lama berbanding yang baharu di sebelah kanan.
Terima kasih kepada perubahan itu, tiada apa yang akan mengganggu kandungan anda.
Toastify__toast mempunyai beberapa nilai lalai yang wajar (cth., jejari sempadan, bayang, dll...) yang boleh disesuaikan menggunakan css atau dengan mengemas kini pembolehubah css yang berkaitan:
width: var(--toastify-toast-width); min-height: var(--toastify-toast-min-height); padding: var(--toastify-toast-padding); border-radius: var(--toastify-toast-bd-radius); box-shadow: var(--toastify-toast-shadow); max-height: var(--toastify-toast-max-height); font-family: var(--toastify-font-family);
Membenarkan bar kemajuan tersuai tiada dalam senarai tugasan saya sama sekali semasa bekerja pada keluaran ini. Tetapi melihat betapa mudahnya untuk menyesuaikan pemberitahuan sekarang, saya tidak dapat menahannya ?.
Bahagian terbaiknya ialah anda tidak perlu berkompromi dengan ciri seperti autoTutup, jedaOnHover, jedaOnFocusLoss atau bar kemajuan terkawal—ia hanya berfungsi dengan lancar untuk anda.
Berikut ialah intipati kecil.
function App() { const notify = () => { toast(CustomComponent, { autoClose: 8000, // removes the built-in progress bar customProgressBar: true }); }; return ( <div> <button onClick={notify}>notify</button> <ToastContainer /> </div> ); } // isPaused is now available in your component // it tells you when to pause the animation: pauseOnHover, pauseOnFocusLoss etc... function CustomComponent({ isPaused, closeToast }: ToastContentProps) { return ( <div> <span>Hello</span> <MyCustomProgressBar isPaused={isPaused} onAnimationEnd={() => closeToast()} /> </div> ); }
Tuju ke stackblitz untuk mendapatkan contoh langsung.
ToastContainer dan roti bakar menerima prop ariaLabel(akhirnya...). Ini agak membantu untuk pembaca skrin dan juga untuk ujian.
Contohnya, dalam cypress anda boleh melakukan cy.findByRole("alert", {name: "label aria yang anda nyatakan"}).
import { ToastContainer, toast } from 'react-toastify'; function App(){ const notify = () => toast("Wow so easy !"); return ( <div> <button onClick={notify}>Notify !</button> <ToastContainer /> </div> ); }
Jika pemberitahuan kelihatan dan pengguna menekan alt ia akan menumpukan pada pemberitahuan pertama yang membolehkan pengguna menggunakan Tab untuk menavigasi elemen berbeza dalam pemberitahuan itu.
Kekunci panas sudah tentu boleh ditukar.
width: var(--toastify-toast-width); min-height: var(--toastify-toast-min-height); padding: var(--toastify-toast-padding); border-radius: var(--toastify-toast-bd-radius); box-shadow: var(--toastify-toast-shadow); max-height: var(--toastify-toast-max-height); font-family: var(--toastify-font-family);
Adakah anda ingin tahu sama ada pengguna menutup pemberitahuan atau jika ia ditutup secara automatik? Yakinlah, ini kini boleh dilakukan!
Tandatangan panggilan balik onClose kini onClose(sebab?: boolean | rentetan) => batal.
Apabila pengguna menutup pemberitahuan, hujah sebabnya adalah sama dengan benar. Dalam contoh di bawah, saya telah menamakan hujah saya
removeByUser untuk menjelaskan niat.
function App() { const notify = () => { toast(CustomComponent, { autoClose: 8000, // removes the built-in progress bar customProgressBar: true }); }; return ( <div> <button onClick={notify}>notify</button> <ToastContainer /> </div> ); } // isPaused is now available in your component // it tells you when to pause the animation: pauseOnHover, pauseOnFocusLoss etc... function CustomComponent({ isPaused, closeToast }: ToastContentProps) { return ( <div> <span>Hello</span> <MyCustomProgressBar isPaused={isPaused} onAnimationEnd={() => closeToast()} /> </div> ); }
Jika anda menggunakan komponen tersuai untuk pemberitahuan anda, anda mungkin mahu lebih kawalan ke atas sebabnya, terutamanya jika ia mengandungi
berbilang seruan tindak.
toast("hello", { ariaLabel: "something" })
Kail itu tidak boleh digunakan melainkan anda menyelam lebih dalam dalam kod sumber react-toastify untuk memahami cara melekatkan sesuatu. Ini bukan yang saya mahukan untuk pengguna saya, ia adalah keputusan yang tidak baik untuk mendedahkan mereka pada mulanya, saya telah belajar pengajaran yang baik.
Setelah difikirkan, saya tidak sepatutnya melakukan ini. Ciri ini boleh dikatakan tidak digunakan. Di bawah tandatangan baharu untuk setiap panggilan balik:
Saya sedang menulis semula sebahagian daripada dokumentasi secara beransur-ansur. Saya telah mencipta koleksi pada stackblitz, dengan cara ini anda boleh mencari semua contoh di satu tempat. Saya akan terus menambah lebih banyak contoh semasa saya pergi.
Atas ialah kandungan terperinci React-toastify v- akhirnya mudah untuk disesuaikan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!