ホームページ >ウェブフロントエンド >jsチュートリアル >React でコンポーネントを作成する 3 つの方法は何ですか?

React でコンポーネントを作成する 3 つの方法は何ですか?

王林
王林転載
2020-12-01 15:37:091974ブラウズ

React でコンポーネントを作成する 3 つの方法は何ですか?

React でコンポーネントを作成する 3 つの方法とその類似点と相違点の紹介:

1. 機能コンポーネント

(推奨チュートリアル: react チュートリアル)

1. 文法

function myConponent(props) {
	return `Hello${props.name}`
}

2. 機能

新しいフック API については、公式 Web サイトにアクセスしてください。以前はステートレスでしたが、コンポーネントはステートフルにできるようになりました

コンポーネントはこのオブジェクトにアクセスできません

ライフサイクル メソッドにアクセスできません

3. 提案:

If可能であれば、ステートレス コンポーネントを使用し、コンポーネントをシンプルかつステートレスに保つようにしてください。 [作成者が意味するのは、親コンポーネントを使用してサブコンポーネントを制御しようとすることです。サブコンポーネントは表示に使用され、親コンポーネントはロジックを担当します]

2. es5 の React.createClass コンポーネント

1. 構文

var myCreate = React.createClass({
	defaultProps: {
		//code
	},
	getInitialState: function() {
		return { //code };
	},
	render:function(){
		return ( //code );
	}
})

2. 機能

このメソッドは比較的古いため、徐々に削除される予定です

3.es6 メソッド クラス:

1. 構文:

class InputControlES6 extends React.Component {
	constructor(props) {
		super(props);
		this.state = {
			state_exam: props.exam
		}
		//ES6类中函数必须手动绑定
		this.handleChange = this.handleChange.bind(this);
	}
	handleChange() {
		this.setState({
			state_exam: 'hello world'
		});
	}
	render() {
		return( //code )
	};
}

2. 機能:

メンバー関数はこれを自動的にバインドしないため、開発者は手動でバインドする必要があります。そうしないと、これを取得できません。現在のコンポーネント インスタンス オブジェクト。

State 状態はコンストラクターで初期化されます

props 属性タイプとコンポーネントのデフォルト属性は、コンポーネント インスタンスの属性ではなく、コンポーネント クラスの属性として使用されるため、クラスが使用されます。

コンポーネント作成の基本原則を覚えておいてください:

1. コンポーネント名の最初の文字は大文字にする必要があります

2. コンポーネントには 1 つのルート ノードのみを含めることができます (このルート ノードをタグで囲みたくない場合は、Fragment

3 を導入できます。機能コンポーネントを使用して、シンプルかつステートレスに保つようにしてください。

最後に、比較してみましょう関数コンポーネントとそのクラスコンポーネント 関数の書き方の違い:

親コンポーネントが制御する状態の比較

関数コンポーネント:

function App(props) {
	function handleClick() {
		props.dispatch({ type: 'app/create' });
	}
	return <div onClick={handleClick}>{props.name}</div>
}

クラスコンポーネント

class App extends React.Component {
	handleClick() {
		this.props.dispatch({ type: &#39;app/create&#39; });
	}
	render() {
		return <div onClick={this.handleClick.bind(this)}>{this.props.name}</div>
	}
}

自己維持状態の比較

import React, { useState } from &#39;react&#39;;
function App(props) {
	const [count, setCount] = useState(0);
	function handleClick() {
		setCount(count + 1);
	}
	return <div onClick={handleClick}>{count}</div>
}

クラスコンポーネント:

class App extends React.Component {
	state = { count: 0 }
	handleClick() {
		this.setState({ count: this.state.count +1 })
	}
	render() {
		return <div onClick={this.handleClick.bind(this)}>{this.state.count}</div>
	}
}

以上がReact でコンポーネントを作成する 3 つの方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はcsdn.netで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。