cari

Cangkuk penghala reaksi

React Router V5 memperkenalkan mekanisme cangkuk yang kuat, menyediakan empat cangkuk penghalaan yang mudah, memudahkan pengurusan penghalaan. Artikel ini dengan cepat akan bermula dengan mod baru React Router V5, mula -mula memperkenalkan mod rendering routing baru, dan kemudian menyelidiki penggunaan setiap cangkuk.

React Router Sebelum V5

 // membuat laluan dan dapatkan atribut laluan<route component="{Home}" path="/"></route>

// lulus sifat tambahan<route path="/" render="{({" match><profile match="{match}" mine="{true}"></profile> } /></route>

Apabila menggunakan sintaks component , sifat penghalaan ( match , location , dan history ) secara tersirat diserahkan kepada komponen. Tetapi jika anda perlu lulus sifat tambahan, anda mesti menggunakan harta render . Harus diingat bahawa menambahkan fungsi inline ke sintaks component akan menyebabkan komponen untuk diperbaiki setiap kali ia diberikan.

React Router selepas v5

<route path="/"><home></home></route>

Komponen Home tidak lagi secara tersirat menerima sifat penghalaan. Walau bagaimanapun, anda boleh menambah sebarang sifat tambahan ke komponen Home tanpa mengubahsuai Route sendiri. Elakkan masalah komponen pengangkatan setiap kali mereka memberikan, yang merupakan reka bentuk API yang lebih ringkas dan cekap.

Oleh kerana sifat penghalaan tidak lagi tersirat, bagaimana untuk mengakses match , history , atau location ? Adakah saya perlu membungkus semua komponen dengan withRouter ? Di sinilah cangkuk itu bermain.

Perhatikan bahawa cangkuk diperkenalkan dalam React 16.8, jadi React diperlukan untuk digunakan.

Hook useHistory

  • Menyediakan akses kepada atribut history dalam Router React.
  • Titik kepada kebergantungan pakej history yang digunakan oleh laluan.
  • Ia digunakan terutamanya untuk penghalaan programatik melalui fungsi, seperti push , replace , dll.
 import {useHistory} dari 'react-router-dom';

fungsi rumah () {
  const history = useHistory ();
  kembali <button onclick="{()">sejarah.push ('/profil')}> profil</button> ;
}

cangkuk useLocation

  • Menyediakan akses kepada atribut location dalam penghala React.
  • Sama seperti window.location penyemak imbas, tetapi ia mewakili status penghalaan dan lokasi dan boleh diakses di mana -mana sahaja.
  • Terutamanya digunakan untuk mengakses parameter pertanyaan atau rentetan penghalaan lengkap.
 import {uselocation} dari 'react-router-dom';

profil fungsi () {
  const location = uselocation ();
  useeffect (() => {
    const currentPath = location.pathName;
    const searchParams = urlSearchParams baru (location.search);
    // ... Gunakan CurrentPath dan SearchParams
  }, [lokasi]);
  Kembali<p> Profil</p> ;
}

Oleh kerana harta location tidak berubah, useEffect memanggil fungsi setiap kali perubahan laluan, yang bagus untuk memanipulasi parameter carian atau laluan semasa.

useParams Hook

  • Menyediakan akses kepada parameter dalam URL.
  • Ciri ini sebelum ini hanya dilaksanakan melalui match.params .
 import {useParams, route} dari 'react-router-dom';

profil fungsi () {
  const {name} = useParams ();
  Kembali<p> Profil {Name}</p> ;
}

fungsi papan pemuka () {
  Kembali (
    <div>
      <nav>
        <link to="{`/profile/ann`}">Profil Ann
      </nav>
      <main>
        <route path="/profile/:name"><profile></profile></route>
      </main>
    </div>
  );
}

useRouteMatch Hook

  • Menyediakan akses kepada objek match .
  • Sekiranya tidak ada hujah, perlawanan terdekat dalam komponen atau komponen induknya dikembalikan.
  • Terutamanya digunakan untuk membina laluan bersarang.
 import {userouteMatch, route} dari 'react-router-dom';

fungsi auth () {
  const match = userOuteMatch ();
  Kembali (
    <div>
      <route path="{`${match.url}/login`}"><login></login></route>
      <route path="{`${match.url}/register`}"><register></register></route>
    </div>
  );
}

useRouteMatch juga boleh digunakan untuk mengakses objek match tanpa membuat Route dengan lulus parameter location .

Sebagai contoh, katakan anda perlu membuat profil anda dalam /profile , dan jika URL mengandungi nama orang ( /profile/dan atau /profile/ann ), menjadikan profil orang lain. Jika anda tidak menggunakan cangkuk, anda perlu menulis Switch , senaraikan dua laluan dan menyesuaikan dengan alat peraga. Tetapi sekarang, menggunakan Hook boleh melakukan ini:

 import {route, browserrouter sebagai penghala, pautan, useroutematch} dari 'react-router-dom';

profil fungsi () {
  const Match = UserOuteMatch ('/profil/: nama');
  Perlawanan balik?<p> {match.params.name} 's Profil</p> :<p> Profil saya sendiri</p> ;
}

Eksport App Fungsi Lalai () {
  Kembali (
    <router>
      <nav>
        <link to="/profile">Profil saya
        <br>
        <link to="{`/profile/ann`}">Profil Ann
      </nav>
      <route path="/profile"><profile></profile></route>
    </router>
  );
}

Anda juga boleh lulus semua sifat Route seperti exact atau sensitive sebagai objek ke useRouteMatch .

Meringkaskan

Hook dan Route eksplisit sendiri mempunyai kelebihan tersembunyi. Cangkuk ini membantu mengelakkan banyak kekeliruan dan kerumitan yang muncul dalam mod awal, mengurangkan kesilapan manusia, menjadikan kod penghalaan lebih mudah untuk dikekalkan, dan lebih mudah untuk menaik taraf ke versi Router React baru.

Atas ialah kandungan terperinci Cangkuk penghala reaksi. 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
Gaya CSS peringkat seterusnya untuk kursorGaya CSS peringkat seterusnya untuk kursorApr 23, 2025 am 11:04 AM

Kursor adat dengan CSS adalah hebat, tetapi kita boleh mengambil sesuatu ke peringkat seterusnya dengan JavaScript. Menggunakan JavaScript, kita boleh beralih antara negeri kursor, letakkan teks dinamik dalam kursor, gunakan animasi kompleks, dan gunakan penapis.

Dunia bertembung: Pengesanan Perlanggaran Kerangka Key menggunakan pertanyaan gayaDunia bertembung: Pengesanan Perlanggaran Kerangka Key menggunakan pertanyaan gayaApr 23, 2025 am 10:42 AM

Animasi CSS interaktif dengan unsur -unsur yang menghilangkan satu sama lain kelihatan lebih masuk akal pada tahun 2025. Walaupun tidak perlu untuk melaksanakan pong dalam CSS, peningkatan fleksibiliti dan kuasa CSS mengukuhkan kecurigaan Lee '

Menggunakan penapis latar belakang CSS untuk kesan UIMenggunakan penapis latar belakang CSS untuk kesan UIApr 23, 2025 am 10:20 AM

Petua dan cara untuk menggunakan harta penapis latar belakang CSS ke antara muka pengguna gaya. Anda akan belajar bagaimana untuk meletakkan penapis latar belakang di antara pelbagai elemen, dan mengintegrasikannya dengan kesan grafik CSS yang lain untuk membuat reka bentuk yang rumit.

SMIL ON?SMIL ON?Apr 23, 2025 am 09:57 AM

Nah, ternyata ciri-ciri animasi terbina dalam SVG ' s tidak pernah ditamatkan seperti yang dirancang. Pasti, CSS dan JavaScript lebih mampu membawa beban, tetapi ia baik untuk mengetahui bahawa SMIL tidak mati di dalam air seperti sebelumnya

'Cantik' berada di mata penonton'Cantik' berada di mata penontonApr 23, 2025 am 09:40 AM

Yay, let ' s melompat untuk teks-wrap: Pretty Landing dalam Pratonton Teknologi Safari! Tetapi berhati -hatilah bahawa ia ' s berbeza dari bagaimana ia berfungsi dalam pelayar kromium.

CSS-Tricks Chronicles XLIIICSS-Tricks Chronicles XLIIIApr 23, 2025 am 09:35 AM

Kemas kini trik CSS ini menyoroti kemajuan yang ketara dalam almanak, penampilan podcast baru-baru ini, panduan kaunter CSS baru, dan penambahan beberapa penulis baru yang menyumbang kandungan berharga.

Ciri tailwind ' s @ply lebih baik daripada bunyiCiri tailwind ' s @ply lebih baik daripada bunyiApr 23, 2025 am 09:23 AM

Kebanyakan masa, orang mempamerkan ciri-ciri Tailwind ' Apabila dipamerkan dengan cara ini, @apply tidak menjanjikan sama sekali. Jadi obvio

Rasa seperti saya tidak mempunyai pelepasan: perjalanan ke arah penyebaran yang warasRasa seperti saya tidak mempunyai pelepasan: perjalanan ke arah penyebaran yang warasApr 23, 2025 am 09:19 AM

Menggunakan seperti idiot datang ke ketidakcocokan antara alat yang anda gunakan untuk menggunakan dan ganjaran dalam kerumitan dikurangkan berbanding kerumitan yang ditambah.

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

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa