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

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

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

onclickとはユーザーのクリック処理を指します。これは"onmousedown"(押下)と"onmouseup"(押上)の二つの事象の組み合わせです

JavaScript

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

React.js

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

Q&A

解決済

1回答

15760閲覧

【React】【ReactModal】onClickで複数の処理を行いたい

sunuo

総合スコア1

onclick

onclickとはユーザーのクリック処理を指します。これは"onmousedown"(押下)と"onmouseup"(押上)の二つの事象の組み合わせです

JavaScript

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

React.js

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

0グッド

0クリップ

投稿2020/12/15 14:47

前提・実現したいこと

Reactの練習で自己紹介ページを作っています。
自己紹介編集画面をReactModalを用いて作成しようと試みています。
SAVEボタンを押したときに、データを保存しModalWindowを閉じる処理を同時に行うように実装を行いたかったのですが
うまく行きませんでした。
onCliickの中でコンマを使えないのは知っているのですが、ボタンクリックされたときに2つの処理を実行させたいです。
ちなみにキャンセルボタンは想定通りの動きをし、this.saveProfileのみならデータは想定通りに保存されています。
ご教授いただけますと幸いです。

該当のソースコード

親コンポーネント

JavaScript

1 openModal = () => { 2 this.setState({isModalOpen: true}) 3 } 4 5 closeModal = () => { 6 this.setState({isModalOpen: false}) 7 } 8 9 render(){ 10 return ( 11 <div> 12 <h2>Profile</h2> 13 <Button 14 label={'Edit Profile'} 15 onClick={this.openModal} 16 /> 17 <EditProfile 18 openModal = {this.state.isModalOpen} 19 onClose = {this.closeModal} 20 /> 21 </div> 22 ) 23 }

子コンポーネント

JavaScript

1render(){ 2 return( 3 <div> 4 <ReactModal 5 isOpen = {this.props.openModal} 6 > 7           ・・・ 8           <名前や年齢などのプロフィールをInputで入力します。略> 9 ・・・ 10           <Button 11 label={'Save'} 12 onClick = { 13 this.saveProfile, 14 this.props.onClose 15 } 16 /> 17 <Button 18 label={'Cancel'} 19 onClick={this.props.onClose} 20 /> 21 </ReactModal> 22 </div> 23 ) 24 }

試したこと

下記などを参考にonClickで複数の処理の実行ができないか試したのですが、うまく実装することができませんでした。
https://www.366service.com/jp/qa/b582191adb9bfb525d728951fcbafb7a

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

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

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

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

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

guest

回答1

0

ベストアンサー

引数を渡さないのであれば簡単です。

JavaScript

1           <Button 2 label={'Save'} 3 onClick = {() => { 4 this.saveProfile(); 5 this.props.onClose(); 6 }} 7 />

としてあげればよいでしょう。

投稿2020/12/19 07:39

A_kirisaki

総合スコア2853

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

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

sunuo

2020/12/20 08:46

ありがとうございます。無事想定通りの動きをしました。 大変助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問