React.jsの小道具

php中世界最好的语言
リリース: 2018-03-13 14:51:27
オリジナル
1822 人が閲覧しました

今回は React.js の props について説明します。 React.js の props を使用する際の注意点は何ですか? 以下は実際的なケースです。
親コンポーネントは子コンポーネントに値を渡します

<Son userid={123}/>
ログイン後にコピー

Sonコンポーネントは親コンポーネントによって渡された値を受け取ります

<p>接收到的父页面的属性 -- userid: {this.props.userid} username:{this.props.username}</p>
ログイン後にコピー

もちろん、Sonページで渡されたパラメータの型とデフォルト値を設定することもできます

// 给属性设置类型BodyIndex.propTypes = {    // isRequired 必须的参数
    userid: React.PropTypes.number.isRequired,
    username: React.PropTypes.string
}// 设置默认值BodyIndex.defaultProps = {
    username: &#39;哈哈&#39;}
ログイン後にコピー

型の設定の詳細については、公式ドキュメントを参照してください

MyComponent.propTypes = { // You can declare that a prop is a specific JS primitive. By default, these
 // are all optional.
 optionalArray: PropTypes.array, optionalBool: PropTypes.bool, optionalFunc: PropTypes.func, optionalNumber: PropTypes.number, optionalObject: PropTypes.object, optionalString: PropTypes.string, optionalSymbol: PropTypes.symbol, // Anything that can be rendered: numbers, strings, elements or an   array// (or fragment) containing these types.optionalNode: PropTypes.node,// A React element.optionalElement: PropTypes.element, // You can also declare that a prop is an instance of a class. This uses
  // JS&#39;s instanceof operator.
  optionalMessage: PropTypes.instanceOf(Message),  // You can ensure that your prop is limited to specific values by treating
  // it as an enum.
  optionalEnum: PropTypes.oneOf([&#39;News&#39;, &#39;Photos&#39;]),  // An object that could be one of many types
  optionalUnion: PropTypes.oneOfType([
    PropTypes.string,
    PropTypes.number,
    PropTypes.instanceOf(Message)
  ]),  // An array of a certain type
  optionalArrayOf: PropTypes.arrayOf(PropTypes.number),  // An object with property values of a certain type
  optionalObjectOf: PropTypes.objectOf(PropTypes.number),  // An object taking on a particular shape
  optionalObjectWithShape: PropTypes.shape({    color: PropTypes.string,    fontSize: PropTypes.number
  }),  // You can chain any of the above with `isRequired` to make sure a warning
  // is shown if the prop isn&#39;t provided.
  requiredFunc: PropTypes.func.isRequired,  // A value of any data type
  requiredAny: PropTypes.any.isRequired,  // You can also specify a custom validator. It should return an Error
  // object if the validation fails. Don&#39;t `console.warn` or throw, as this
  // won&#39;t work inside `oneOfType`.
  customProp: function(props, propName, componentName) {    if (!/matchme/.test(props[propName])) {      return new Error(        &#39;Invalid prop `&#39; + propName + &#39;` supplied to&#39; +        &#39; `&#39; + componentName + &#39;`. Validation failed.&#39;
      );
    }
  },  // You can also supply a custom validator to `arrayOf` and     `objectOf`.
  // It should return an Error object if the validation fails. The validator
  // will be called for each key in the array or object. The first two
  // arguments of the validator are the array or object itself, and the
  // current item&#39;s key.
  customArrayProp: PropTypes.arrayOf(function(propValue, key,       componentName, location, propFullName) {    if (!/matchme/.test(propValue[key])) {      return new Error(        &#39;Invalid prop `&#39; + propFullName + &#39;` supplied to&#39; +        &#39; `&#39; + componentName + &#39;`. Validation failed.&#39;
      );
    }
  })
 };
ログイン後にコピー

Sonコンポーネントは、親コンポーネントから渡されたプロパティを孫コンポーネントに渡します

演算子

{...this.props}を展開することで、 、親コンポーネントから渡されたすべてのプロパティは、それ自体の子コンポーネント (Sunchild コンポーネント) に渡されます
id={1234} は、Son コンポーネントによって孫コンポーネントに渡される属性です

孫コンポーネントは、孫コンポーネントから渡された属性を呼び出しますSon コンポーネント
<p>{this.props.userid} {this.props.username} {this.props.id}</p>
ログイン後にコピー

refs: コンポーネントの内部 DOM ノードにアクセスする唯一の信頼できる方法です

タグに ref を追加します

<input ref=&#39;submitButton&#39; type="button" value=&#39;提交&#39; onClick={() => this.changeUserInfo(99)}/>
ログイン後にコピー

dom を取得したい場合は、this.refs.xxx を通して取得します

this.refs.submitButton.style.color = &#39;red&#39;;
ログイン後にコピー
注:

レンダリングまたはレンダリングの前に Refs を呼び出さないでください。

Refs を乱用しないでください。使用しないでください。!!!

を読んだ後は、このメソッドを習得したと思います。この記事のケースについては、さらに興味深い情報については、php 中国語 Web サイトの他の関連記事にご注目ください。

推奨読書:

Vue.jsルーティングパラメータ


Vue.jsカスタムディレクティブディレクティブ


Vue.jsからjs実装への移行


以上がReact.jsの小道具の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート