Rumah hujung hadapan web tutorial css Cangkuk penghala reaksi

Cangkuk penghala reaksi

Apr 11, 2025 am 09:49 AM

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>
Salin selepas log masuk

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>
Salin selepas log masuk

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> ;
}
Salin selepas log masuk

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> ;
}
Salin selepas log masuk

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>
  );
}
Salin selepas log masuk

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>
  );
}
Salin selepas log masuk

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>
  );
}
Salin selepas log masuk

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 Laman Web ini
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

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

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Vue 3 Vue 3 Apr 02, 2025 pm 06:32 PM

Ia &#039; s! Tahniah kepada pasukan Vue untuk menyelesaikannya, saya tahu ia adalah usaha besar dan lama datang. Semua dokumen baru juga.

Membina aplikasi Ethereum menggunakan redwood.js dan fauna Membina aplikasi Ethereum menggunakan redwood.js dan fauna Mar 28, 2025 am 09:18 AM

Dengan pendakian harga bitcoin baru -baru ini lebih dari 20k $ USD, dan baru -baru ini melanggar 30k, saya fikir ia patut mengambil menyelam yang mendalam kembali ke dalam mewujudkan Ethereum

Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Apr 02, 2025 pm 06:17 PM

Saya mempunyai seseorang yang menulis dengan soalan yang sangat legit ini. Lea hanya blog tentang bagaimana anda boleh mendapatkan sifat CSS yang sah dari penyemak imbas. That &#039; s seperti ini.

Kad yang disusun dengan kedudukan melekit dan sasaran sass Kad yang disusun dengan kedudukan melekit dan sasaran sass Apr 03, 2025 am 10:30 AM

Pada hari yang lain, saya melihat sedikit ini sangat indah dari laman web Corey Ginnivan di mana koleksi kad timbunan di atas satu sama lain semasa anda menatal.

Sedikit di CI/CD Sedikit di CI/CD Apr 02, 2025 pm 06:21 PM

Saya &#039;

Membandingkan penyemak imbas untuk reka bentuk responsif Membandingkan penyemak imbas untuk reka bentuk responsif Apr 02, 2025 pm 06:25 PM

Terdapat beberapa aplikasi desktop ini di mana matlamat menunjukkan laman web anda pada dimensi yang berbeza pada masa yang sama. Oleh itu, anda boleh menulis

Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Apr 02, 2025 am 04:27 AM

Jika kita perlu menunjukkan dokumentasi kepada pengguna secara langsung dalam editor WordPress, apakah cara terbaik untuk melakukannya?

Kenapa kawasan -kawasan yang dikurangkan ungu di susun atur flex tersilap dianggap sebagai 'ruang limpahan'? Kenapa kawasan -kawasan yang dikurangkan ungu di susun atur flex tersilap dianggap sebagai 'ruang limpahan'? Apr 05, 2025 pm 05:51 PM

Soalan mengenai kawasan slash ungu dalam susun atur flex Apabila menggunakan susun atur flex, anda mungkin menghadapi beberapa fenomena yang mengelirukan, seperti dalam alat pemaju (D ...

See all articles