Latest web development tutorials

bereaksi Props

Perbedaan utama antara negara dan alat peragaalat peraga yang berubah, sementara negara dapat berinteraksi dengan pengguna untuk mengubah.Inilah sebabnya mengapa beberapa komponen kontainer perlu mendefinisikan negara untuk memperbarui dan memodifikasi data. Sub-perakitan hanya dapat melewatkan data melalui alat peraga.


Gunakan Props

Contoh berikut menunjukkan bagaimana menggunakan alat peraga dalam perakitan:

var HelloMessage = React.createClass({
  render: function() {
    return <h1>Hello {this.props.name}</h1>;
  }
});

ReactDOM.render(
  <HelloMessage name="w3big" />,
  document.getElementById('example')
);

Coba »

This.props.name atribut nama contoh untuk melewati.


Props standar

Anda dapat mengatur nilai default untuk alat peraga oleh getDefaultProps () metode, contoh adalah sebagai berikut:

var HelloMessage = React.createClass({
  getDefaultProps: function() {
    return {
      name: 'w3big'
    };
  },
  render: function() {
    return <h1>Hello {this.props.name}</h1>;
  }
});

ReactDOM.render(
  <HelloMessage />,
  document.getElementById('example')
);

Coba »


Negara dan Props

Contoh berikut menunjukkan bagaimana menggunakan kombinasi negara dan alat peraga dalam aplikasi. Kita bisa mengatur negara dalam perakitan orangtua, dan melalui penggunaan alat peraga dalam sub-perakitan untuk ditransfer ke sub-perakitan. Dalam fungsi render, kita menetapkan nama dan lokasi untuk mendapatkan komponen orangtua melewati data.

var WebSite = React.createClass({
  getInitialState: function() {
    return {
      name: "本教程",
      site: "http://www.w3big.com"
    };
  },
 
  render: function() {
    return (
      <div>
        <Name name={this.state.name} />
        <Link site={this.state.site} />
      </div>
    );
  }
});

var Name = React.createClass({
  render: function() {
    return (
      <h1>{this.props.name}</h1>
    );
  }
});

var Link = React.createClass({
  render: function() {
    return (
      <a href={this.props.site}>
        {this.props.site}
      </a>
    );
  }
});

React.render(
  <WebSite />,
  document.getElementById('example')
);

Coba »


verifikasi props

Props otentikasi menggunakanpropTypes, dapat memastikan bahwa komponen aplikasi kami digunakan dengan benar, React.PropTypes menawarkan banyak validator (validator) untuk memvalidasi data yang masuk adalah valid.Ketika alat peraga tidak valid data yang masuk, Console JavaScript akan melempar peringatan.

Contoh berikut membuat komponen Mytitle, judul properti adalah suatu keharusan dan string, angka akan diberikan jika:

var title = "本教程";
// var title = 123;
var MyTitle = React.createClass({
  propTypes: {
    title: React.PropTypes.string.isRequired,
  },

  render: function() {
     return <h1> {this.props.title} </h1>;
   }
});
ReactDOM.render(
    <MyTitle title={title} />,
    document.getElementById('example')
);

Coba »

Jika judul menggunakan variabel numerik, menghibur pesan kesalahan berikut:

Lebih validator sebagai berikut:

React.createClass({
  propTypes: {
    // 可以声明 prop 为指定的 JS 基本数据类型,默认情况,这些数据是可选的
   optionalArray: React.PropTypes.array,
    optionalBool: React.PropTypes.bool,
    optionalFunc: React.PropTypes.func,
    optionalNumber: React.PropTypes.number,
    optionalObject: React.PropTypes.object,
    optionalString: React.PropTypes.string,

    // 可以被渲染的对象 numbers, strings, elements 或 array
    optionalNode: React.PropTypes.node,

    //  React 元素
    optionalElement: React.PropTypes.element,

    // 用 JS 的 instanceof 操作符声明 prop 为类的实例。
    optionalMessage: React.PropTypes.instanceOf(Message),

    // 用 enum 来限制 prop 只接受指定的值。
    optionalEnum: React.PropTypes.oneOf(['News', 'Photos']),

    // 可以是多个对象类型中的一个
    optionalUnion: React.PropTypes.oneOfType([
      React.PropTypes.string,
      React.PropTypes.number,
      React.PropTypes.instanceOf(Message)
    ]),

    // 指定类型组成的数组
    optionalArrayOf: React.PropTypes.arrayOf(React.PropTypes.number),

    // 指定类型的属性构成的对象
    optionalObjectOf: React.PropTypes.objectOf(React.PropTypes.number),

    // 特定 shape 参数的对象
    optionalObjectWithShape: React.PropTypes.shape({
      color: React.PropTypes.string,
      fontSize: React.PropTypes.number
    }),

    // 任意类型加上 `isRequired` 来使 prop 不可空。
    requiredFunc: React.PropTypes.func.isRequired,

    // 不可空的任意类型
    requiredAny: React.PropTypes.any.isRequired,

    // 自定义验证器。如果验证失败需要返回一个 Error 对象。不要直接使用 `console.warn` 或抛异常,因为这样 `oneOfType` 会失效。
    customProp: function(props, propName, componentName) {
      if (!/matchme/.test(props[propName])) {
        return new Error('Validation failed!');
      }
    }
  },
  /* ... */
});