🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

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

Q&A

解決済

1回答

1483閲覧

Reactでselectタグで選択した内容とinputで入力した内容を結びつけて表示を出し分けたい

NY9

総合スコア5

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

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

0グッド

0クリップ

投稿2019/10/03 00:58

前提・実現したいこと

時間割アプリのようなものを作っていて、selectタグで曜日を選択しinputで授業名を入力すると、選択された曜日の下だけに"◯限 国語"のように表示をしたいのですが今のままではすべての曜日の下に表示されてしまいます。
特定の曜日の下だけに表示するにはどうしたらよいでしょうか?

Javascript

1import React from 'react'; 2import Loop from './Loop'; 3 4const fixed= ["月曜日","火曜日","水曜日","木曜日","金曜日"] 5 6class App extends React.Component{ 7 constructor(props) { 8 super(props); 9 this.state = { 10 lists:[], 11 input:"", 12 value:"", 13 days:"", 14 } 15 this.handleChange = this.handleChange.bind(this); 16 this.handleSubmit = this.handleSubmit.bind(this); 17 this.handleChangeDays = this.handleChangeDays.bind(this); 18 } 19 20 render () { 21 let list; 22 23 list = <Loop lists={this.state.lists}/> 24 25 return ( 26 27 <div> 28 <h1>時間割</h1> 29 <form> 30 <select value={this.state.days} 31 onChange={this.handleChangeDays}> 32 <option value="none">---</option> 33 <option value="月曜日">月曜日</option> 34 <option value="火曜日">火曜日</option> 35 <option value="水曜日">水曜日</option> 36 <option value="木曜日">木曜日</option> 37 <option value="金曜日">金曜日</option> 38 </select> 39 40 <select value={this.state.value} 41 onChange={this.handleChangeOrders}> 42 <option value="none">---</option> 43 <option value="1限:">1限</option> 44 <option value="2限:">2限</option> 45 <option value="3限:">3限</option> 46 <option value="4限:">4限</option> 47 <option value="5限:">5限</option> 48 </select> 49 50 <input 51 onChange={this.handleChange} 52 type="text" 53 name="input" 54 value={this.state.input} 55 /> 56 57 <button onClick={this.handleSubmit}>保存</button> 58 <button>削除</button> 59 </form> 60 61 62 {fixed.map((l) =>( 63 <div key={l.toString()}> 64 <p>{l}</p> 65 <p>{list}</p> 66 </div> 67 ))} 68 69 </div> 70 ); 71 } 72 73 handleChange = (event) => { 74 this.setState({input:event.target.value}) 75 } 76 handleChangeDays = (event) => { 77 this.setState({days:event.target.value}) 78 } 79 handleChangeOrders = (event) => { 80 this.setState({value:event.target.value}) 81 } 82 83 handleSubmit (e) { 84 e.preventDefault(); 85 if (!this.state.input) return; 86 this.setState( 87 { 88 lists: [ 89 ...this.state.lists, 90 { 91 input: this.state.input, 92 value: this.state.value 93 }], 94 input:"", 95 days:"", 96 value:"" 97 }); 98 }; 99 100} 101 102export default App;

Javascript

1import React from 'react'; 2 3class Loop extends React.Component { 4 render () { 5 return ( 6 <div> 7 {this.props.lists.map((l) =>( 8 <div key={l.days}> 9 <p>{l.days}{l.value}{l.input}</p> 10 </div> 11 ))} 12 </div> 13 ); 14 } 15} 16 17export default Loop; 18

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんにちは

<p>{list}</p> として表示している list は、以下

jsx

1list = <Loop lists={this.state.lists}/>

のように、全アイテムを含む Loopコンポーネントとして作成しているので、各曜日に該当するアイテムのみの配列を渡した、 Loopを渡すようにします。

具体的な修正箇所は以下の3点です。

(1) <p>{list}</p>  の部分を以下のように修正

jsx

1<p> 2 <Loop 3 lists={this.state.lists.filter(item => item.days === l)} 4 /> 5</p>

(2) 上記により変数 list が不要になるので、以下の2行を削除

jsx

1let list; 2 3list = <Loop lists={this.state.lists}/>

(3) handleSubmit の中で setState する箇所で、追加する要素に days がないので追加

javascript

1 this.setState( 2 { 3 lists: [ 4 ...this.state.lists, 5 { 6 input: this.state.input, 7 value: this.state.value, 8 days: this.state.days //この行を追加 9 }], 10 input:"", 11 days:"", 12 value:"" 13 });

以下は、上記3点を修正後のコードをCodePenに上げたものです。

以上、参考になれば幸いです。

投稿2019/10/03 03:38

編集2019/10/03 03:43
jun68ykt

総合スコア9058

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問