15
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Reactチュートリアルをやってみた

15
Last updated at Posted at 2023-04-21

教材

はじめに

仕事でReactに触れる事になりましたが、全然わかっていない・・・

Reactを知るなら、まずはコレをしたほうがいいと推薦があったのでやることにしました
今はReact Hooksが主流になっているので、業務ではあまり使われない書き方もありますが、基本となる部分が理解できるようです

開発準備

  • チュートリアルに書いてあるCodePenを利用して開発環境を用意します
  1. スターターコードを開きます
  2. 画面、右下にあるForkボタンで自分のアカウントにスターターコードを派生させます
  3. 表示レイアウトを変更してコードが長く見えるようにしました
    change-view.png
  4. 以下のような表示にして準備完了です
    01.png

チュートリアル開始

Reactとは?

React はユーザインターフェイスを構築するための、宣言型で効率的で柔軟な JavaScript ライブラリです。複雑な UI を、「コンポーネント」と呼ばれる小さく独立した部品から組み立てることができます。

冒頭に書いてあるということは、コンポーネント(小さくした部品)というのを意識したほうがよさそう・・・

コンポーネント

いくつか異なるコンポーネントクラスがあるらしいけど、チュートリアルはReact.Componentを使うらしい

props, render

コンポーネントは props(“properties” の略)と呼ばれるパラメータを受け取り、render メソッドを通じて、表示するビューの階層構造を返します。

render メソッドが返すのはあなたが画面上に表示したいものの説明書きです。React はその説明書きを受け取って画面に描画します。
具体的には、render は、描画すべきものの軽量な記述形式である React 要素というものを返します。
たいていの React 開発者は、これらの構造を簡単に記述できる “JSX” と呼ばれる構文を使用しています。
<div /> という構文は、ビルド時に React.createElement('div') に変換されます。

propsでメソッドの引数のように値を渡せそう
renderで表示したい内容を書きそう

チュートリアルのコンポーネント

コードを見てみると、3 つの React コンポーネントがあることが分かります。

Square(正方形のマス目)
Board(盤面)
Game

チュートリアルに書いてあるのを忠実に書き写す

内容を書いていくとチュートリアルの写経になってしまうので割愛しますが、調べた事を書いていきます

アロー関数構文

チュートリアルのリンク先が英語だったので、日本語で書いてくれている記事を探しました

State

state と props の違いは何ですか?
props(“properties” を短くしたもの)と state は、両方ともプレーンな JavaScript のオブジェクトです。どちらもレンダー結果に影響を及ぼす情報を持ってはいますが、ある重要な一点が異なっています。つまり、props は(関数引数のように)コンポーネントへ渡されるのに対し、state は(関数内で宣言された変数のように)コンポーネントの内部で制御されます。

値の保持に利用する感じ
更新するときに利用するsetStateは非同期。なので、this.stateが最新の値になっているかは保証されていない

どうすればいいの?

どうやって現在の state に依存する値を更新したらいいですか?
setState へオブジェクトを渡す代わりに関数を渡してください。その関数は常に最新の状態の state を使って呼ばれることが保証されています(次項参照)。

setState へオブジェクトを渡すのと関数を渡すのとのでは何が違いますか?
更新関数を渡すと、その関数内で現在の state の値へアクセスできるようになります。setState 呼び出しはバッチ処理されるため、更新処理を連結して、それぞれの更新が競合せずに順序だって動作することが保証されます。

setStateを使うときは、更新関数を利用するといい

イミュータブル,ミュータブル

変更の検出をするために、直接書き換え(ミュータブルな操作)すると差分チェックができないため
更新するべきコンポーネントを探しやすい

完成

最後に

  • チュートリアルの所要時間

    • 1時間くらいで完了できる内容になっていました
    • 一旦、3目並べとしてなら、もう少し短く済みそう
  • つまったところ

    • Stateを管理するコンポーネントを変更していきながら進んでいくので、State、Propsあたりで混乱しました
    • エラーで動作しなくなることもありましたが、チュートリアルの中に、途中段階のコードがちょくちょくあるので、見比べたりコピペしたりして、エラーを解消できました
  • 学んだ点

    • とりあえずReactに足を踏み入れたという感じはします
    • Stateが非同期ということなので、作っていく段階でアレ?っていう動作をしそうなコードを書きそうだと感じました
      • ライフサイクルを勉強したほうがココらへんが、落とし込める気がします
    • チュートリアルでは触れられていない関数コンポーネントとか、まだ複数のコンポーネントがありそうです

最近のサービスのフロントエンドは、ボタンを押したとかのアクションに素早く応答して画面に表現してくれます
Reactを勉強して、今のフロントエンドを理解できるようにしていこうと思います

15
4
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
15
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?