ホームページ >ウェブフロントエンド >jsチュートリアル >React 入門: React でコンポーネントを作成する方法
コンポーネントを作成する前に、次の点に注意してください:
コンポーネント名の最初の文字は大文字にする必要があります
コンポーネントで返されるJSXはルートのみにすることができますノードであり、すべてのコンテンツは 1 つの要素を使用する必要があります
ステートレス機能コンポーネントは、コードがより読みやすく、合理化され、便利になり、冗長性が軽減されることを理解できます。ステートレス コンポーネントには次の特性があります:
コンポーネントはインスタンス化できず、全体的なレンダリングが向上します
インスタンス化されていないため、コンポーネントはこのオブジェクトにアクセスできません
コンポーネントにはライフサイクルがありません
import React from 'react' import { connect } from 'dva'; function CreateComponent(props) { console.log(props); return ( <p> <span>{props.name}今年{props.age}岁</span> </p> ) } export default connect(state => ({ name:'小明', age:15 }))(CreateComponent);
import React from 'react' class CreateComponent extends React.Component { render() { return( <p> <h2>标题</h2> <ul> <li>首先</li> <li>其次</li> <li>最后</li> </ul> </p> ) } } export default CreateComponent;上の例では、h2 要素と h2 要素の両方に p を使用しています。 ul. まとめ1. コンポーネントのイベント監視
import React from 'react' class CreateComponent extends React.Component { clickFunc = (e) => { console.log("监听:",e.target.innerHTML); } clickValue = (value) => { console.log(value); } render() { return ( <p> <a onClick={this.clickFunc}>监听事件</a> <br/> <a onClick={this.clickValue.bind(this,123)}>this对象</a> </p> ) } } export default CreateComponent;
import React from 'react' class CreateComponent extends React.Component { state = { flag : true } clickValue = () => { this.setState({ flag: !this.state.flag }) } render() { return ( <p> <span>flag的值为:{this.state.flag ? '真' : '假'}</span> <br/> <button onClick={this.clickValue}>改变flag值</button> </p> ) } } export default CreateComponent;
import React from 'react'; function NewComponent(props) { return ( <p> {props.content} </p> ); } export default NewComponent;ここから、props が属性であることがわかります。コンポーネントによってもたらされる値。Props は実際に外部コンポーネントの設定を許可し、state はコンポーネントが自身を制御する状態です。
コンストラクターコンポーネントの初期化:
コンストラクターいくつかのパラメーターのプロパティなどを初期化します。import React from 'react' import NewComponent from './newComponent.js' class CreateComponent extends React.Component { render() { return ( <p> <NewComponent content={'我是内容'} /> </p> ) } } export default CreateComponent;出力結果:
import React from 'react' class CreateComponent extends React.Component { constructor () { super() console.log('construct:页面初始化') } componentWillMount () { console.log('componentWillMount:页面将要渲染') } componentDidMount () { console.log('componentDidMount:页面渲染结束') } render() { console.log('render:页面渲染'); return ( <p> 页面渲染 </p> ) } } export default CreateComponent;
componentWillUnmountコンポーネントの削除
construct:页面初始化 componentWillMount:页面将要渲染 render:页面渲染 componentDidMount:页面渲染结束
import React from 'react'; class NewComponent extends React.Component { componentWillUnmount() { console.log('componentWillUnmount:将要从页面中删除'); } render() { return ( <p> {this.props.content} </p> ); } } export default NewComponent;削除ボタンをクリックすると、コンポーネント NewComponent が削除され、componentWillUnmount 関数が実行されます。削除前出力結果:
import React from 'react' import NewComponent from "./newComponent.js"; class CreateComponent extends React.Component { constructor () { super() console.log('construct:页面初始化'); this.state = { content:'测试组件', isDelete:false } } componentWillMount () { console.log('componentWillMount:页面将要渲染') } componentDidMount () { console.log('componentDidMount:页面渲染结束') } deleteFunc = () => { this.setState({ isDelete:true }) } render() { console.log('render:页面渲染'); return ( <p> 页面渲染 <input type="button" value='删除' onClick={this.deleteFunc}/> {!this.state.isDelete?( <NewComponent content={this.state.content}/> ):(null)} </p> ) } } export default CreateComponent;上記のライフサイクルは、一般的に使用されるコンポーネントのライフサイクルです。ライフサイクルには更新フェーズのライフサイクルもありますが、これらは比較的まれに使用されます。
shouldComponentUpdate(nextProps, nextState)
以下に示すように、コンポーネントを再レンダリングするかどうかを制御しますconstruct:页面初始化 componentWillMount:页面将要渲染 render:页面渲染 componentDidMount:页面渲染结束 componentWillUnmount:将要从页面中删除。これは、 shouldComponentUpdate で戻り値が false に設定されているため、ページは再描画できません。この関数の最初のパラメータは最新のプロパティを表し、2 番目のパラメータは最新の状態を表します
componentWillReceiveProps(nextProps)
import React from 'react' import NewComponent from "./newComponent.js"; class CreateComponent extends React.Component { constructor () { super() console.log('construct:页面初始化'); this.state = { content:'测试组件', isDelete:false } } componentWillMount () { console.log('componentWillMount:页面将要渲染') } componentDidMount () { console.log('componentDidMount:页面渲染结束') } shouldComponentUpdate(nextProps, nextState){ if(nextState.isDelete){ return false; } } deleteFunc = () => { this.setState({ isDelete:true }) } render() { console.log('render:页面渲染'); return ( <p> 页面渲染 <input type="button" value='删除' onClick={this.deleteFunc}/> {!this.state.isDelete?( <NewComponent content={this.state.content}/> ):(null)} </p> ) } } export default CreateComponent;コンポーネント CreateComponent 内:
import React from 'react'; class NewComponent extends React.Component { componentWillUnmount() { console.log('componentWillUnmount:将要从页面中删除'); } componentWillReceiveProps(nextProps){ console.log(nextProps); } render() { return ( <p> {this.props.content} </p> ); } } export default NewComponent;ただし、componentWillReceiveProps は、react16.3.0 の開始後に非推奨になります
componentDidUpdate:
コンポーネントは再レンダリングされ、変更が実際の DOM に変更されます。後で呼び出してくださいReact コンポーネント Dragact 0.1.4 の詳細な説明
以上がReact 入門: React でコンポーネントを作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。