0
2

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】基礎編⓶

Posted at

今回は前回の【React】基礎編⓵に引き続き、
【React】基礎編⓶でReactにおいての、
Componentについて、propsについて、Reactの流れ・仕組みについての3つを主体として
詳細に紹介できればと思います。

【React】基礎編⓵のリンクは下記からお願いします。↓↓↓
https://qiita.com/Yu-8chan/items/28ebf04f899639b0f536

Componentとは

コンポーネントは「部品」や「パーツ」という意味です。
Reactでは、見た目を機能ごとにコンポーネント化して、コンポーネントを組み合わせることでWebサイトの見た目を作ります。

Componentの構成

Languageコンポーネントを作成するために、構成を学んでいきましょう。
① Reactをimportします。
② React.Componentを継承するLanguageクラスを作成します。このクラスがコンポーネントとなります。
③ 作成したクラスの中で、renderメソッドを定義し、return内にJSXを記述します。
④ コンポーネントをexportします。

Language.js
import React from 'react'; 
// クラス名がコンポーネントの名前になります
class Language extends React.Conponent { 
  render() { 
    return(
      ---JSX---
    );
  }
}

export default Language; 

Componentの表示

Componentを表示する手順は3つです。

① Languageコンポーネントをexportします。

Language.js
import React from 'react'; 
class Language extends React.Conponent { 
  render() { 
    return(
      ---JSX---
    );
  }
}
// Languageコンポーネントをexport
export default Language; 

② LanguageコンポーネントをApp.js内でimportします。
③ JSX内に<コンポーネント名 />と書きます。

Componentの特徴として、何度でも呼び出すことができます。

App.js
import React from 'react'; 
// Languageコンポーネントをimport
import Language from './Language';
class App extends React.Conponent { 
  render() { 
    return(
      // JSX内に<コンポーネント名 />と書く
      <Language />
      <Language />
      <Language /> // 何度でも呼び出せる
    );
  }
}

export default App; 

propsとは

App.jsから、部分的に変更したいデータをLanguageコンポーネントに渡すことによって、部分的に表示を変えることができます。App.jsから渡すこのデータをprops(プロップス)といいます。

propsの渡し方

propsは、「props名=値」という形で、コンポーネントを呼び出す箇所で渡します。
今回は、Languageコンポーネントにnameのpropsを渡しています。

App.js
import React from 'react'; 
import Language from './Language';
class App extends React.Conponent { 
  render() { 
    return(
      <Language 
        // 「props名 = 値」
        name = "HTML&CSS"
      />
    );
  }
}

export default App; 

渡されたpropsは、this.propsで取得できます。
propsの中身を見てみると、this.propsは{ props名: 値 }というオブジェクトになります。

App.js
    return(
      <Language 
        // 「props名 = 値」
        name = "HTML&CSS"
      />
    );
Language.js
    return(
      console.log(this.props);
      // 出力内容: {name: "HTML&CSS"}
    );

propsの取得

this.propsと書くことで{props名: 値}というオブジェクトを取得できるので、
「this.props.props名」とすることでpropsの値を取得できます。
下図では、取得したpropsを用いて、言語の名前を表示しています。

Language.js
import React from 'react'; 
class App extends React.Conponent { 
  render() { 
    return(
      <p>この言語は{this.props.name}です</p>
      // 出力内容: この言語はHTML&CSSです
    );
  }
}

export default App; 

もう一工夫

propsを使うことで、1つのコンポーネントで色んな言語の紹介を表示することができることがわかりました。
ですが、もし100言語あったら、下図のように書くのは大変ですよね。

App.js
  render() { 
    return(
      <Language name = "HTML&CSS"/>
      <Language name = "PHP"/>
      <Language name = "Ruby"/>
      <Language name = "React"/>
                 .
                 .
    );
  }

そこでです。mapメソッドを使えばコンポーネントを何度も繰り返し呼ぶことができます。

mapメソッド

では、mapメソッドを使って効率的に表示していきましょう。
下図のように、言語ごとの情報を持つlanguageList配列に対して、mapメソッドを用いると、簡単に各言語のLanguageコンポーネントを表示できます
① 各オブジェクトを配列で取得します。
② mapメソッドを使って各オブジェクトごとに表示します。
③ nameに各オブジェクトのprops(name)を代入します。

App.js
  render() { 
    const languageList = [  // 言語ごとの情報を持つlanguageList配列
      {name: "HTML&CSS"},
      {name: "PHP"},
      {name: "Ruby"},
      {name: "React"},
    ];
    return(
      <div>
        {languageList.map((languageName) => {  // languageNameに各オブジェクトが挿入
          return(
            <Language 
              name = {languageName.name}  // nameに各オブジェクトのprops(name)を代入
            />
          );
        })};
      </div>
    );
  }
Language.js
  render() { 
    return(
      <p>この言語は{this.props.name}です</p>
      // 各言語の名前が表示されます
    );
  }

Reactの表示と仕組み

ここでは表示の流れを見ていきましょう。
Image from Gyazo

Language.js(Languageクラスをexport)
       ↓
App.js(Languageクラスをimport)
       ↓
index.js(App.jsのJSXをHTMLに変換される)
       ↓
index.html(id名rootにindex.jsの内容が挿入され、index.htmlの内容がブラウザに表示される)

Language.js
class Language extends React.Conponent { 
  render() { 
    return(
      ---JSX---
    );
  }
}
export default Language; // Languageコンポーネントをexport
App.js
import React from 'react'; 
import Language from './Language'; // Languageコンポーネントの内容をimport
class App extends React.Conponent { 
  render() { 
    return(
      <Language />
    );
  }
}

export default App; 
index.js
import React from './components/App'; 
ReactDom.render(<App />, document.getElementById('root'));
// <App />と書くことでApp.jsのJSXがHTMLに変換されます
// document.getElementById('root')で指定したid名の場所に挿入
index.html
<body>
  <div id="root"></div>
<body>

以上でReactの基礎編終了です。

0
2
0

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
0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?