質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

1191閲覧

React ウェブサイト制作 何から始める

Yusuke_m25

総合スコア74

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

1クリップ

投稿2020/03/20 06:11

HTMLとCSSとjQueryでウェブ制作をしてきた人間です。
今後のことを考えてreactを身につけようとチュートリアルを済ませて、何か作ろうと手をつけ始めました。
今までの制作実績をとりあえずreactで並べてみようと思いました。
その際に<画像><タイトル><要約>がワンセットで何個も繰り返される事が予想されるので、ここがコンポーネントになるんだろうなと思いました。
ただ、チュートリアルの五目並べを作っただけでは全くサイトの作り方の予想がつかず,,,

例えば連想配列に

javascript

1works = { 2{1:{img:OOO.png , title:OOOOO , text:OOOO}}, 3{2:{img:OOO.png , title:OOOOO , text:OOOO}}, 4{3:{img:OOO.png , title:OOOOO , text:OOOO}} 5};

制作実績のデータを詰め込んで、それの数だけfor文でコンポーネントにpropsを渡しながら回していくのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

works を配列にして、for でゃなく map を使いましょう。

jsx

1const works = [ 2 {img:OOO.png , title:OOOOO , text:OOOO}, 3 {img:OOO.png , title:OOOOO , text:OOOO}, 4 {img:OOO.png , title:OOOOO , text:OOOO} 5]; 6 7const App = () => { 8 return ( 9 <div> 10 <h1>My Workd</h1> 11 <ul> 12 { 13 works.map((work, index) => 14 <li key={work.title}> 15 <img src={work.img} /> 16 <div className='title'>{index + 1}. {work.title}</div> 17 <div className='text'>{work.text}</div> 18 </li> 19 ) 20 } 21 </ul> 22 </div> 23 ); 24};

さらに <li></li> をコンポーネント化します。

jsx

1const Work = ({ work, index }) => { 2 return ( 3 <li key={work.title}> 4 <img src={work.img} /> 5 <div className='title'>{index + 1}. {work.title}</div> 6 <div className='text'>{work.text}</div> 7 </li> 8 ); 9}; 10 11const App = () => { 12 return ( 13 <div> 14 <h1>My Workd</h1> 15 <ul> 16 { 17 works.map((work, index) => <Work key={index} work={work} index={index} />) 18 } 19 </ul> 20 </div> 21 ); 22};

あとは、react-router を入れて作品の詳細ページを SPA で遷移したり、作品がたくさんあればページネーションしたり、作品データを JSON 化して AJAX で取得したりしていけば良いのではないでしょうか。

投稿2020/03/20 06:59

hoshi-takanori

総合スコア7901

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Yusuke_m25

2020/03/22 01:04

map、そういえばやりました。 ありがとうございます。 jsonやAjaxも理解していない部分なので合わせて学習を進めてみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問