Rumah hujung hadapan web tutorial js Komponen Tulen dalam React.js

Komponen Tulen dalam React.js

Oct 24, 2024 am 03:17 AM

Pure Component in React.jsMemastikan komponen tulen ialah prinsip asas dalam React dan pengaturcaraan berfungsi. Berikut ialah penerokaan yang lebih mendalam tentang konsep ketulenan dalam komponen, termasuk faedah dan strategi untuk mengekalkan ketulenan dalam komponen React anda.


Memastikan Komponen Tulen dalam Tindak Balas

Apakah Fungsi Tulen?

Satu fungsi tulen ialah fungsi yang:

  1. Deterministik: Memandangkan input yang sama, ia sentiasa menghasilkan output yang sama.
  2. Tiada Kesan Sampingan: Ia tidak menyebabkan sebarang kesan sampingan, seperti mengubah suai keadaan luaran atau berinteraksi dengan dunia luar (cth., membuat panggilan API, memanipulasi DOM).

Mengapa Menggunakan Komponen Tulen?

  1. Kebolehramalan: Komponen tulen berkelakuan secara konsisten. Anda boleh bergantung pada output mereka, yang memudahkan penaakulan tentang aplikasi.

  2. Pengujian Lebih Mudah: Memandangkan komponen tulen boleh diramal dan tiada kesan sampingan, ia lebih mudah untuk diuji. Anda boleh terus menguji output berdasarkan prop input tanpa perlu risau tentang perubahan keadaan luaran.

  3. Pengoptimuman Prestasi: Komponen tulen membantu mengoptimumkan pemaparan. React boleh menentukan dengan cekap sama ada komponen perlu dipaparkan semula berdasarkan perubahan prop.

  4. Kebolehselenggaraan: Apabila pangkalan kod anda berkembang, mengekalkan komponen tulen menjadi lebih mudah. Ia merangkumi fungsi tanpa kebergantungan tersembunyi, menjadikan penyahpepijatan dan pemfaktoran semula lebih mudah.

  5. Guna Semula: Komponen tulen sangat boleh digunakan semula kerana ia tidak bergantung pada keadaan luaran. Anda boleh menggunakannya dengan mudah dalam konteks yang berbeza.

Cara Mengekalkan Komponen Tulen

Berikut ialah beberapa strategi untuk memastikan komponen anda kekal tulen:

  1. Elakkan Kesan Sampingan:
    • Jangan ubah suai prop atau keadaan global secara langsung.
    • Elakkan operasi tak segerak dalam kaedah pemaparan (cth., panggilan API, pemasa).
   const PureComponent = ({ count }) => {
     // Pure function: does not cause side effects
     return <div>{count}</div>;
   };
Salin selepas log masuk
  1. Gunakan React.memo:
    • Balut komponen berfungsi dengan React.memo untuk mengelakkan pemaparan semula yang tidak perlu apabila prop tidak berubah.
   const PureGreeting = React.memo(({ name }) => {
     return <h1>Hello, {name}!</h1>;
   });
Salin selepas log masuk
  1. Prop Pemusnah:
    • Memusnahkan prop dalam senarai parameter komponen untuk memastikan struktur komponen bersih dan fokus.
   const PureButton = ({ label, onClick }) => {
     return <button onClick={onClick}>{label}</button>;
   };
Salin selepas log masuk
  1. Naikkan Keadaan:
    • Urus keadaan dalam komponen induk dan turunkan data dan pengendali peristiwa yang diperlukan kepada komponen anak. Ini memastikan komponen kanak-kanak berfungsi sepenuhnya.
   const ParentComponent = () => {
     const [count, setCount] = useState(0);

     return <PureCounter count={count} setCount={setCount} />;
   };
Salin selepas log masuk
  1. Elakkan Fungsi Sebaris dalam Render:
    • Daripada mentakrifkan fungsi sebaris dalam kaedah pemaparan, tentukannya di luar. Ini menghalang kejadian fungsi baharu daripada dibuat pada setiap pemaparan, yang boleh menyebabkan pemaparan semula yang tidak perlu.
   const PureCounter = React.memo(({ count, setCount }) => {
     return <button onClick={() => setCount(count + 1)}>Increment</button>;
   });
Salin selepas log masuk
  1. Elakkan Keadaan Berubah Secara Terus:
    • Gunakan kaedah yang mengembalikan keadaan baharu dan bukannya mengubah keadaan sedia ada secara langsung. Ini sejajar dengan prinsip kebolehubah.
   const handleAddItem = (item) => {
     setItems((prevItems) => [...prevItems, item]); // Pure approach
   };
Salin selepas log masuk

Contoh Komponen Tulen

Berikut ialah contoh lengkap komponen berfungsi tulen yang mengikut prinsip ini:

import React, { useState } from 'react';

const PureCounter = React.memo(({ count, onIncrement }) => {
  console.log('PureCounter Rendered');
  return <button onClick={onIncrement}>Count: {count}</button>;
});

const App = () => {
  const [count, setCount] = useState(0);

  const handleIncrement = () => {
    setCount((prevCount) => prevCount + 1);
  };

  return (
    <div>
      <h1>Pure Component Example</h1>
      <PureCounter count={count} onIncrement={handleIncrement} />
    </div>
  );
};

export default App;
Salin selepas log masuk

Kesimpulan

Memastikan komponen tulen dalam React bukan sahaja memudahkan pembangunan tetapi juga meningkatkan prestasi dan kebolehselenggaraan. Dengan mematuhi prinsip fungsi tulen, anda boleh mencipta komponen yang boleh diramal, boleh digunakan semula dan mudah untuk diuji. Mengikuti amalan terbaik seperti mengelakkan kesan sampingan, menggunakan React.memo dan mengurus keadaan dengan sewajarnya boleh membantu anda membina aplikasi yang teguh dan boleh dijual.

Atas ialah kandungan terperinci Komponen Tulen dalam React.js. 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)

Apa yang perlu saya lakukan jika saya menghadapi percetakan kod yang dihiasi untuk resit kertas terma depan? Apa yang perlu saya lakukan jika saya menghadapi percetakan kod yang dihiasi untuk resit kertas terma depan? Apr 04, 2025 pm 02:42 PM

Soalan dan penyelesaian yang sering ditanya untuk percetakan tiket kertas terma depan dalam pembangunan front-end, percetakan tiket adalah keperluan umum. Walau bagaimanapun, banyak pemaju sedang melaksanakan ...

Demystifying JavaScript: Apa yang berlaku dan mengapa penting Demystifying JavaScript: Apa yang berlaku dan mengapa penting Apr 09, 2025 am 12:07 AM

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Siapa yang dibayar lebih banyak Python atau JavaScript? Siapa yang dibayar lebih banyak Python atau JavaScript? Apr 04, 2025 am 12:09 AM

Tidak ada gaji mutlak untuk pemaju Python dan JavaScript, bergantung kepada kemahiran dan keperluan industri. 1. Python boleh dibayar lebih banyak dalam sains data dan pembelajaran mesin. 2. JavaScript mempunyai permintaan yang besar dalam perkembangan depan dan stack penuh, dan gajinya juga cukup besar. 3. Faktor mempengaruhi termasuk pengalaman, lokasi geografi, saiz syarikat dan kemahiran khusus.

Bagaimana untuk mencapai kesan menatal paralaks dan kesan animasi elemen, seperti laman web rasmi Shiseido?
atau:
Bagaimanakah kita dapat mencapai kesan animasi yang disertai dengan menatal halaman seperti laman web rasmi Shiseido? Bagaimana untuk mencapai kesan menatal paralaks dan kesan animasi elemen, seperti laman web rasmi Shiseido? atau: Bagaimanakah kita dapat mencapai kesan animasi yang disertai dengan menatal halaman seperti laman web rasmi Shiseido? Apr 04, 2025 pm 05:36 PM

Perbincangan mengenai realisasi kesan animasi tatal dan elemen Parallax dalam artikel ini akan meneroka bagaimana untuk mencapai yang serupa dengan laman web rasmi Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ... ...

Adakah JavaScript sukar belajar? Adakah JavaScript sukar belajar? Apr 03, 2025 am 12:20 AM

Pembelajaran JavaScript tidak sukar, tetapi ia mencabar. 1) Memahami konsep asas seperti pembolehubah, jenis data, fungsi, dan sebagainya. 2) Pengaturcaraan asynchronous tuan dan melaksanakannya melalui gelung acara. 3) Gunakan operasi DOM dan berjanji untuk mengendalikan permintaan tak segerak. 4) Elakkan kesilapan biasa dan gunakan teknik debugging. 5) Mengoptimumkan prestasi dan mengikuti amalan terbaik.

Evolusi JavaScript: Trend Semasa dan Prospek Masa Depan Evolusi JavaScript: Trend Semasa dan Prospek Masa Depan Apr 10, 2025 am 09:33 AM

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

Bagaimana untuk menggabungkan elemen array dengan ID yang sama ke dalam satu objek menggunakan JavaScript? Bagaimana untuk menggabungkan elemen array dengan ID yang sama ke dalam satu objek menggunakan JavaScript? Apr 04, 2025 pm 05:09 PM

Bagaimana cara menggabungkan elemen array dengan ID yang sama ke dalam satu objek dalam JavaScript? Semasa memproses data, kita sering menghadapi keperluan untuk mempunyai id yang sama ...

Bagaimana untuk melaksanakan fungsi seretan panel dan drop pelarasan yang serupa dengan vscode dalam pembangunan front-end? Bagaimana untuk melaksanakan fungsi seretan panel dan drop pelarasan yang serupa dengan vscode dalam pembangunan front-end? Apr 04, 2025 pm 02:06 PM

Terokai pelaksanaan fungsi seretan panel dan drop panel seperti VSCode di bahagian depan. Dalam pembangunan front-end, bagaimana untuk melaksanakan vscode seperti ...

See all articles