Rumah > hujung hadapan web > tutorial js > Bagaimanakah Saya Boleh Menghantar Props kepada Komponen Pengendali dalam Penghala Reaksi?

Bagaimanakah Saya Boleh Menghantar Props kepada Komponen Pengendali dalam Penghala Reaksi?

Patricia Arquette
Lepaskan: 2024-10-23 18:44:31
asal
569 orang telah melayarinya

How Can I Pass Props to Handler Components in React Router?

Melalukan Props kepada Komponen Pengendali dalam Penghala Reaksi

Dalam Penghala Reaksi, menghantar prop kepada komponen pengendali adalah keperluan biasa. Pertimbangkan struktur berikut:

var Dashboard = require('./Dashboard');
var Comments = require('./Comments');

var Index = React.createClass({
  render: function () {
    return (
        <div>
            <header>Some header</header>
            <RouteHandler />
        </div>
    );
  }
});

var routes = (
  <Route path="/" handler={Index}>
    <Route path="comments" handler={Comments}/>
    <DefaultRoute handler={Dashboard}/>
  </Route>
);

ReactRouter.run(routes, function (Handler) {
  React.render(<Handler/>, document.body);
});
Salin selepas log masuk

Melalui Props Secara Terus

Secara tradisinya, anda akan menghantar prop terus kepada komponen Komen seperti ini:

<Comments myprop="value" />
Salin selepas log masuk

Melalui Props melalui React Router

Walau bagaimanapun, dalam React Router, prop mesti melalui prop komponen Route. Terdapat dua cara untuk melakukan ini:

1. Menggunakan Komponen Pembalut

Buat komponen pembalut yang melilit komponen pengendali:

var RoutedComments = React.createClass({
  render: function () {
    return <Comments {...this.props} myprop="value" />;
  }
});
Salin selepas log masuk

Kemudian, gunakan komponen RoutedComments bukannya komponen Comments dalam laluan:

<Route path="comments" handler={RoutedComments}/>
Salin selepas log masuk

2. Menggunakan Komponen Kelas dengan Sifat Laluan

Tentukan komponen kelas yang memanjang dari React.Component dan gunakan prop komponen:

class Index extends React.Component {
  constructor(props) {
    super(props);
  }
  render() {
    return (
      <h1>
        Index - {this.props.route.foo}
      </h1>
    );
  }
}

var routes = (
  <Route path="/" foo="bar" component={Index}/>
);
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menghantar Props kepada Komponen Pengendali dalam Penghala Reaksi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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