cari
Rumahhujung hadapan webtutorial jsReact-toastify v- akhirnya mudah untuk disesuaikan

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.

React-toastify v- finally easy to customize

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 ?!

React-toastify v- finally easy to customize

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.

React-toastify v- finally easy to customize

  • 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.

React-toastify v- finally easy to customize

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. React-toastify v- finally easy to customize

? 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.

React-toastify v- finally easy to customize

Atas ialah kandungan terperinci React-toastify v- akhirnya mudah untuk disesuaikan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Aliran node.js dengan typescriptAliran node.js dengan typescriptApr 30, 2025 am 08:22 AM

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

Python vs JavaScript: Pertimbangan Prestasi dan KecekapanPython vs JavaScript: Pertimbangan Prestasi dan KecekapanApr 30, 2025 am 12:08 AM

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.

Asal JavaScript: Meneroka Bahasa PelaksanaannyaAsal JavaScript: Meneroka Bahasa PelaksanaannyaApr 29, 2025 am 12:51 AM

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.

Di sebalik tabir: Apa bahasa JavaScript?Di sebalik tabir: Apa bahasa JavaScript?Apr 28, 2025 am 12:01 AM

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.

Masa Depan Python dan JavaScript: Trend dan RamalanMasa Depan Python dan JavaScript: Trend dan RamalanApr 27, 2025 am 12:21 AM

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.

Python vs JavaScript: Persekitaran dan Alat PembangunanPython vs JavaScript: Persekitaran dan Alat PembangunanApr 26, 2025 am 12:09 AM

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.

Adakah JavaScript ditulis dalam C? Memeriksa buktiAdakah JavaScript ditulis dalam C? Memeriksa buktiApr 25, 2025 am 12:15 AM

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.

Peranan JavaScript: Membuat Web Interaktif dan DinamikPeranan JavaScript: Membuat Web Interaktif dan DinamikApr 24, 2025 am 12:12 AM

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.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

MantisBT

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

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma