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

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

新規登録して質問してみよう
ただいま回答率
86.12%
コンストラクタ

オブジェクト指向言語において、オブジェクトを生成時に呼び出され、データの初期化などを行なう関数・メソッドのことである。

JavaScript

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

関数

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

React.js

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

解決済

React Jsx内での引数の渡し方

退会済みユーザー

退会済みユーザー

総合スコア0

コンストラクタ

オブジェクト指向言語において、オブジェクトを生成時に呼び出され、データの初期化などを行なう関数・メソッドのことである。

JavaScript

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

関数

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

React.js

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

1回答

0リアクション

0クリップ

1817閲覧

投稿2021/08/28 22:39

Reactで複数あるボタンの一つを押したときそのボタンが持つvalue要素をonClickイベントの中に設定した関数の引数として引き渡したいです。

実装したい機能はボタンを複数用意し、ユーザーによってクリックされたボタンに表示しているテキストの内容を変更、またその後の処理のために何らかの属性(name, value等)の値をtrueからfalseまたはfalseからtrueに変更したいです

React

class App extends React.Component{ constructor(props){ super(props); this.state = { value: 0, } nextEvent = (num) =>{ console.log(num + "番目のボタンがクリックされました") } render(){ return( <div> <button type="button" value{*この値を引数にしたい*}="1" onClick=(()=>{nextEvent(引数)})>1</button> <button type="button" value{*この値を引数にしたい*}="2" onClick=(()=>{nextEvent(引数)})>2</button> </div> )} }

上記のような場合 ”引数” の場所にはどのように記述をすればいいのでしょうか?

通常のJavascriptの場合 thisでbutton全体を、またはthis.valueで引き渡すことできると認識しているのですが、今回コンポーネントの中にあるため、this.valueを使ってしまうとコンストラクタの中で設定した値が読み取られてしまいます。
thisを使用した場合はundefinedと表示されました。

試行錯誤の結果、button一つ一つにIdを振り分け、document.getElementById(id).valueとすることで取り出すことができましたがこの場合idごとに記述をする必要があり、とても長いコードになってしまいます。

実装したい機能に対しての違う形でのアプローチもあれば教えていただきたいのですが、おそらく今後もコンストラクタの中で設定した値以外を引数として渡したい場合が出てくると思うのでその方法を教えていただきたいです。

また今回プログラムを製作中にbuttonタグの中のvalueの値を数字の1として設定しようと思ったのですがなぜか文字列の"1"しか登録することができませんでした。buttonタグの何かの属性で数値のまま登録できるものがあれば教えてください。

独学で勉強を始めたばかりなので意味のないことや意味の分からないことをしているかもしれませんが、その点に関しても指摘していただけると嬉しいです

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

同じタグがついた質問を見る

コンストラクタ

オブジェクト指向言語において、オブジェクトを生成時に呼び出され、データの初期化などを行なう関数・メソッドのことである。

JavaScript

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

関数

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

React.js

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