Rumah > hujung hadapan web > tutorial js > Bagaimana untuk menyampaikan prop kanak-kanak kepada ibu bapa dalam React.js?

Bagaimana untuk menyampaikan prop kanak-kanak kepada ibu bapa dalam React.js?

Barbara Streisand
Lepaskan: 2024-11-17 04:05:03
asal
480 orang telah melayarinya

How to Pass Child Props to Parent in React.js?

Menyalurkan Props Anak kepada Ibu Bapa dalam React.js

Konteks

React menyediakan mekanisme komunikasi yang kuat antara komponen ibu bapa dan anak melalui prop. Walau bagaimanapun, mungkin terdapat situasi di mana anda ingin menyerahkan keseluruhan komponen anak bersama-sama propnya kepada ibu bapa. Ini boleh berguna dalam senario di mana anda ingin merangkum logik kompleks dalam kanak-kanak dan menyediakan antara muka yang lebih mudah kepada ibu bapa.

Kebimbangan Berkenaan Hantaran Prop Anak-ke-Ibubapa

Secara sejarah, beberapa pembangun telah mencadangkan menggunakan acara untuk menyampaikan prop kanak-kanak kepada ibu bapa, tetapi pendekatan ini menimbulkan kebimbangan tentang gandingan dan enkapsulasi. Mengakses prop komponen kanak-kanak dan butiran pelaksanaan secara langsung dalam induk boleh menggabungkan komponen dengan ketat dan menghalang usaha pemfaktoran semula.

Pendekatan Disyorkan

Sebaliknya, adalah disyorkan untuk memanfaatkan mekanisme prop induk sedia ada untuk mengakses data kanak-kanak itu. Ini membolehkan ibu bapa menggunakan prop yang diberikannya kepada kanak-kanak, mengelakkan keperluan untuk mengambil prop kanak-kanak dari dalam kanak-kanak itu sendiri.

Pelaksanaan Menggunakan Komponen Kelas

Komponen Kanak-kanak:

class Child extends Component {
  render() {
    return <button onClick={this.props.onClick}>{this.props.text}</button>;
  }
}
Salin selepas log masuk

Komponen Induk:

class Parent extends Component {
  getInitialState() {
    return { childText: "Click me! (parent prop)" };
  }

  render() {
    return (
      <Child
        onClick={this.handleChildClick}
        text={this.state.childText}
      />
    );
  }

  handleChildClick(event) {
    const childText = this.state.childText;

    // Parent has access to child prop
    alert(`The Child button text is: ${childText}`);

    // Parent has access to event target
    alert(`The Child HTML is: ${event.target.outerHTML}`);
  }
}
Salin selepas log masuk

Pelaksanaan Menggunakan Komponen Fungsi

Komponen Anak:

const Child = ({ onClick, text }) => {
  return <button onClick={onClick}>{text}</button>;
};
Salin selepas log masuk

Komponen Induk:

const Parent = ({ childrenData }) => {
  const handleChildClick = (childData, event) => {
    const childText = childData.childText;
    const childNumber = childData.childNumber;

    // Parent has access to child prop
    alert(`The Child button data is: ${childText} - ${childNumber}`);

    // Parent has access to event target
    alert(`The Child HTML is: ${event.target.outerHTML}`);
  };

  return (
    <div>
      {childrenData.map((childData) => (
        <Child
          key={childData.childNumber}
          onClick={(event) => handleChildClick(childData, event)}
          text={childData.childText}
        />
      ))}
    </div>
  );
};
Salin selepas log masuk

Kesimpulan

Dengan menerima mekanisme prop sedia ada dalam React, anda boleh menghantar data dengan berkesan antara induk dan komponen kanak-kanak tanpa memperkenalkan gandingan yang tidak perlu atau melanggar prinsip enkapsulasi. Pendekatan ini memastikan bahawa komponen kekal bebas dan fleksibel, membolehkan kod yang lebih bersih dan boleh diselenggara.

Atas ialah kandungan terperinci Bagaimana untuk menyampaikan prop kanak-kanak kepada ibu bapa dalam React.js?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan