Tidak pernah mendengar tentang react-toastify sebelum ini? Pergi semak demo
Apa yang baharu dalam v11
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.
Tidak perlu mengimport fail css lagi
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></toastcontainer> </div> ); }
Penyesuaian mudah!
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.
- Toastify__toast-body dan anaknya kini hilang sepenuhnya.
- Button Tutup kini menggunakan kedudukan mutlak.
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);
Bar kemajuan tersuai
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></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()} /> </mycustomprogressbar> </div> ); }
Tuju ke stackblitz untuk mendapatkan contoh langsung.
Kebolehcapaian dan navigasi papan kekunci
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></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);
Sebab penyingkiran pemberitahuan dengan panggilan balik onClose
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></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()} /> </mycustomprogressbar> </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" })
? Memecahkan Perubahan
useToastContainer dan useToast tidak lagi terdedah
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.
onClose dan onOpen tidak lagi menerima prop kanak-kanak
Setelah difikirkan, saya tidak sepatutnya melakukan ini. Ciri ini boleh dikatakan tidak digunakan. Di bawah tandatangan baharu untuk setiap panggilan balik:
- diBuka: () => batal
- onClose: (sebab?: boolean | rentetan) => batal
Penggayaan
- react-toastify/dist/ReactToastify.minimal.css telah dialih keluar.
- Scss tiada dalam gambar sekarang. Perpustakaan menggunakan css lama yang bagus.
- bodyClassName dan bodyStyle tidak diperlukan lagi.
- progressBarStyle untuk mengurangkan permukaan api. Ia kini merupakan cara yang lebih baik untuk menyesuaikan segala-galanya tanpa bergantung pada gaya sebaris.
- injectStyle telah dialih keluar. Fungsi ini tidak diperlukan lagi.
- Kelas css Toastify__toast-body dan anak langsungnya telah dialih keluar.
? Pembetulan Pepijat
- tambah sokongan untuk react19 #1177 #1185
- eksport semula CloseButtonProps #1165
- baiki terbaharuOnTop untuk kali ini #1176
- tidak lagi membuang ralat hodoh ini: Tidak dapat menetapkan sifat yang tidak ditentukan (menetapkan 'togol') #1170
- Panggil balik onClose tidak lagi ditangguhkan sehingga animasi keluar selesai #1179
?Apa seterusnya?
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!

Node.js cemerlang pada I/O yang cekap, sebahagian besarnya terima kasih kepada aliran. Aliran memproses data secara berperingkat, mengelakkan beban memori-ideal untuk fail besar, tugas rangkaian, dan aplikasi masa nyata. Menggabungkan sungai dengan keselamatan jenis typescript mencipta powe

Perbezaan prestasi dan kecekapan antara Python dan JavaScript terutamanya dicerminkan dalam: 1) sebagai bahasa yang ditafsirkan, Python berjalan perlahan tetapi mempunyai kecekapan pembangunan yang tinggi dan sesuai untuk pembangunan prototaip pesat; 2) JavaScript adalah terhad kepada benang tunggal dalam penyemak imbas, tetapi I/O multi-threading dan asynchronous boleh digunakan untuk meningkatkan prestasi dalam node.js, dan kedua-duanya mempunyai kelebihan dalam projek sebenar.

JavaScript berasal pada tahun 1995 dan dicipta oleh Brandon Ike, dan menyedari bahasa itu menjadi C. 1.C Language menyediakan keupayaan pengaturcaraan prestasi tinggi dan sistem untuk JavaScript. 2. Pengurusan memori JavaScript dan pengoptimuman prestasi bergantung pada bahasa C. 3. Ciri lintas platform bahasa C membantu JavaScript berjalan dengan cekap pada sistem operasi yang berbeza.

JavaScript berjalan dalam penyemak imbas dan persekitaran Node.js dan bergantung pada enjin JavaScript untuk menghuraikan dan melaksanakan kod. 1) menjana pokok sintaks abstrak (AST) di peringkat parsing; 2) menukar AST ke bytecode atau kod mesin dalam peringkat penyusunan; 3) Laksanakan kod yang disusun dalam peringkat pelaksanaan.

Trend masa depan Python dan JavaScript termasuk: 1. Kedua -duanya akan terus mengembangkan senario aplikasi dalam bidang masing -masing dan membuat lebih banyak penemuan dalam prestasi.

Kedua -dua pilihan Python dan JavaScript dalam persekitaran pembangunan adalah penting. 1) Persekitaran pembangunan Python termasuk Pycharm, Jupyternotebook dan Anaconda, yang sesuai untuk sains data dan prototaip cepat. 2) Persekitaran pembangunan JavaScript termasuk node.js, vscode dan webpack, yang sesuai untuk pembangunan front-end dan back-end. Memilih alat yang betul mengikut keperluan projek dapat meningkatkan kecekapan pembangunan dan kadar kejayaan projek.

Ya, teras enjin JavaScript ditulis dalam C. 1) Bahasa C menyediakan prestasi yang efisien dan kawalan asas, yang sesuai untuk pembangunan enjin JavaScript. 2) Mengambil enjin V8 sebagai contoh, terasnya ditulis dalam C, menggabungkan kecekapan dan ciri-ciri berorientasikan objek C. 3) Prinsip kerja enjin JavaScript termasuk parsing, penyusun dan pelaksanaan, dan bahasa C memainkan peranan penting dalam proses ini.

JavaScript adalah di tengah -tengah laman web moden kerana ia meningkatkan interaktiviti dan dinamik laman web. 1) Ia membolehkan untuk menukar kandungan tanpa menyegarkan halaman, 2) memanipulasi laman web melalui Domapi, 3) menyokong kesan interaktif kompleks seperti animasi dan drag-and-drop, 4) mengoptimumkan prestasi dan amalan terbaik untuk meningkatkan pengalaman pengguna.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma
