Reactトレーニングコース、パート28:React Modern Features、Project Ideas、結論

本日、Reactコースの翻訳の最後の部分で、Reactの最新の機能についてお話しし、Reactアプリケーションのアイデアについて議論します。このコースを受講しながら学んだことを繰り返して、多くを学ぶことができます。



画像



パート1:コースの概要、React、ReactDOM、JSXの人気の理由

パート2:機能コンポーネント

パート3:コンポーネントファイル、プロジェクト構造

パート4:親コンポーネントと子コンポーネント

パート5:TODOアプリケーションの作業の開始、スタイリングの基本

パート6:コースの一部の機能、JSXおよびJavaScriptについて

パート7:インラインスタイル

パート8:TODOアプリケーションの継続的な作業、コンポーネントのプロパティに精通

パート9:コンポーネントのプロパティ

パート10:コンポーネントのプロパティとスタイルの操作に関するワークショップ

パート11:動的マークアップ生成およびマップ配列メソッド

パート12:ワークショップ、TODOアプリケーションの作業の第3段階

パート13:クラスベースのコンポーネント

パート14:クラスベースのコンポーネント、コンポーネントのステータスに関するワークショップ

パート15:コンポーネントヘルスワークショップ

パート16:TODOアプリケーションの作業の第4段階、イベント処理

パート17:TODOアプリケーションの作業の第5段階、コンポーネントの状態の変更

パート18:TODOアプリケーションの作業の6番目の段階

パート19:コンポーネントのライフサイクルメソッド

パート20:条件付きレンダリングの最初のレッスン

パート21:条件付きレンダリングに関する2番目のレッスンとワークショップ

パート22:TODOアプリケーションの作業の第7段階、外部ソースからのデータのダウンロード

パート23:フォームの操作に関する最初のレッスン

パート24:2番目のフォームレッスン

パート25:フォームの操作に関するワークショップ

パート26:アプリケーションアーキテクチャ、コンテナ/コンポーネントパターン

パート27:コースプロジェクト

パート28:現在のReactの機能、プロジェクトのアイデア、結論

終わりです!



レッスン46.最新のReactアプリケーションの開発



オリジナル



Facebookの多くのプログラマーがReactライブラリに取り組んでおり、React周辺の大規模なコミュニティのメンバーがプロジェクトに貢献しています。 これはすべて、Reactが非常に迅速に開発されているという事実につながります。 たとえば、2019年の初めにReactを勉強し、2年前にこのライブラリの資料を見た場合、それらの資料の発行以降にReactで発生した変更に気づかずにはいられません。 たとえば、React 16.3では、いくつかの新しいコンポーネントライフサイクルメソッドが登場し、一部のメソッドは廃止されました。 そして、たとえば、React 16.6にはさらに多くの新機能があります。 React 17.0およびこのライブラリの将来のバージョンでは、膨大な数の革新が期待されています。



次に、Reactの最新の機能について説明します。



これらの機能の多くは、Reactプロジェクトの開発に使用されるツールでサポートされているECMAScript仕様のバージョンに依存しています。 Babelトランスポーターを使用する場合、これは最新のJavaScript機能があることを意味します。 まだ標準に含まれていないプロジェクトでJavaScript機能を使用する場合、標準に含まれていると変更される可能性があることに注意してください。



Reactアプリケーションの開発時に使用できる最新のJavaScript機能の1つは、矢印関数構文を使用してクラスメソッドを宣言する機能です。



テキストフィールドを表示するApp



コンポーネントのコードは次のとおりです。



 import React, {Component} from "react" class App extends Component {   //        constructor() {       super()       this.state = {           firstName: ""       }       this.handleChange = this.handleChange.bind(this)   }     //        handleChange(event) {       const { name, value } = event.target       this.setState({           [name]: value       })   }     render() {       return (           <main>               <form>                   <input                       type="text"                       name="firstName"                       value={this.state.firstName}                       onChange={this.handleChange}                       placeholder="First Name"                   />               </form>               <h1>{this.state.firstName}</h1>           </main>       )   } } export default App
      
      





これは、このアプリケーションのページがブラウザでどのように見えるかです。









ブラウザでのアプリケーション



handleChange()



メソッドを矢印関数として書き直し、コンポーネントコードを次の形式にします。



 import React, {Component} from "react" class App extends Component {   //        constructor() {       super()       this.state = {           firstName: ""       }   }     //        handleChange = (event) => {       const { name, value } = event.target       this.setState({           [name]: value       })   }     render() {       return (           <main>               <form>                   <input                       type="text"                       name="firstName"                       value={this.state.firstName}                       onChange={this.handleChange}                       placeholder="First Name"                   />               </form>               <h1>{this.state.firstName}</h1>           </main>       )   } } export default App
      
      





この変換中に、コードに小さな変更が加えられましたが、これらの変更はメソッドの動作に重大な影響を及ぼします。 矢印関数のthis



は、それらが配置されている字句スコープを示します。 これらの関数はthis



バインディングをサポートしていません。 矢印関数のこの機能は、それらを使用して宣言されたメソッドがクラスコンストラクターでthis



にバインドされる必要がないという事実につながります。



ここで検討する別の可能性は、クラスプロパティを使用することです。 ここで、コンストラクターで状態を初期化するときに、 this.state



を使用します。 そのため、クラスのインスタンスプロパティを作成します。 これで、プロパティをコンストラクタの外部で作成できます。 その結果、次のようにコードを変換できます。



 import React, {Component} from "react" class App extends Component {   //        state = { firstName: "" }     //        handleChange = (event) => {       const { name, value } = event.target       this.setState({           [name]: value       })   }     render() {       return (           <main>               <form>                   <input                       type="text"                       name="firstName"                       value={this.state.firstName}                       onChange={this.handleChange}                       placeholder="First Name"                   />               </form>               <h1>{this.state.firstName}</h1>           </main>       )   } } export default App
      
      





ここで、対応するプロパティを宣言するときに状態を初期化することでコンストラクターを削除したことに注意してください。 すべては、このJS機能が近い将来に標準に含まれることを示しています。



以下は、現在のReact機能のリストです。





一般に、Reactは非常に迅速に開発されているため、Reactの開発に携わるすべての人がこのライブラリのイノベーションを常に監視することをお勧めします



レッスン47. React Project Ideas



オリジナル



Reactの開発中に、私とTodoアプリケーションとミームジェネレーターという2つのプロジェクトを作成しました。 Reactを使用して作成したいものを既に知っている可能性があります。 たぶん、あなたはすでにあなた自身のアプリケーションを開発しています。 まだ決定しておらず、その実践がコンピューターテクノロジーを学ぶための最良の方法である場合、Reactを使用して作成できるWebアプリケーションのさまざまなアイデアを見つけることができる資料です。



レッスン48.結論



オリジナル



おめでとうございます! React Libraryコースを修了しました。 Reactアプリケーションの基本的な構成要素を理解しました。これを使用して、独自のプロジェクトを作成できます。 確かに、Reactを使用して何かを作成する場合は、まだ多くのことを学ぶ必要があるという事実に備えてください。



このコースの開発中に学んだ基本的な概念を見ていきましょう。





ご清聴ありがとうございました!



親愛なる読者! このコースの印象を共有し、Reactを使用して開発したい(または既に開発中の)ことを教えてください。






All Articles