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

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

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

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

React.js

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

Q&A

解決済

1回答

3257閲覧

ReactでのonSubmit,onChangeが効きません。

mikan_professor

総合スコア28

JavaScript

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

React.js

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

0グッド

0クリップ

投稿2020/10/30 04:06

Tsuyano Syodaさんの書籍「React.js&Next.js超入門」を勉強しています。

169ページのフォームの利用で書籍の内容の通りに書いたつもりなのですが、onChangeにてイベントがうまく反映されていないように感じます。

理想的には、
①フォーム内のinputに入力した値が変更され、onChangeによりdoChangeが実行されthis.inputが変化
②フォーム内のsubmitを押すことでonSubmitによりdoSubmitが実行されthis.state.messageが変化
③変化されたstateの内容が反映

と想定しているのですが、①の段階でうまく行っていなく感じました。どこが間違っているのか教えていただきたいです。

JavaScript

1import React from 'react'; 2import logo from './logo.svg'; 3import './App.css'; 4import Rect from "./Rect" 5 6class App extends React.Component { 7 input = ""; 8 9 msgStyle={ 10 fontSize:"20pt", 11 color:"#900", 12 margin:"20px 0px", 13 padding:"5px", 14 }; 15 16 inputStyle={ 17 fontSize:"12pt", 18 padding:"5px" 19 } 20 21 constructor(props) { 22 super(props); 23 this.state={ 24 message:"type your name:" 25 }; 26 this.doChange=this.doChange.bind(this); 27 this.doSubmit=this.doSubmit.bind(this); 28 } 29 30 doChange(event){ 31 this.input=event.target.value; 32 } 33 34 doSubmit(event){ 35 this.setState=({ 36 message:"Hello, "+this.input+"!!" 37 }); 38 event.preventDefault(); 39 } 40 render() { 41 return <div> 42 <h1>React</h1> 43 <h2>{this.state.message}</h2> 44 <form onSubmit={this.doSubmit} > 45 <span style={this.inputStyle}></span>Message: 46 <input type="text" style={this.inputStyle} onChange={this.doChange} /> 47 <input type="submit" style={this.inputStyle} value="Click"/> 48 </form> 49 </div>; 50 } 51} 52 53 54export default App; 55

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

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

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

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

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

guest

回答1

0

ベストアンサー

inputの値をstateで管理してください。
this.inputではrenderには反映されません。

javascript

1 constructor(props) { 2 super(props); 3 this.state={ 4 message:"type your name:", 5 text:"" 6 }; 7 this.doChange=this.doChange.bind(this); 8 this.doSubmit=this.doSubmit.bind(this); 9 } 10 11 doChange(event){ 12 this.setState({text:event.target.value}); //set 13 } 14 15 doSubmit(event){ 16 this.setState=({ 17 message:"Hello, "+this.state.text+"!!" //stateからの参照 18 }); 19 event.preventDefault(); 20 } 21 render() { 22 return <div> 23 <h1>React</h1> 24 <h2>{this.state.message}</h2> 25 <form onSubmit={this.doSubmit} > 26 <span style={this.inputStyle}></span>Message: 27 <input type="text" style={this.inputStyle} 28 onChange={this.doChange} 29 value={this.state.text} // valueもstateからの参照 30 /> 31 <input type="submit" style={this.inputStyle} value="Click"/> 32 </form> 33 </div>; 34 }

投稿2020/10/30 06:15

Hogeike

総合スコア293

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

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

mikan_professor

2020/10/30 06:32

ご回答ありがとうございました。 先程自己解決しました。setState()をsetState=()としていたことが原因で、直したらうまく動きました。
Hogeike

2020/10/30 06:52

確かにそこが根本原因でしたね。失礼いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問