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

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

詳細はこちら
React.js

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

Q&A

1回答

4415閲覧

React 自作のコンポーネントにonClickが効かない

退会済みユーザー

退会済みユーザー

総合スコア0

React.js

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

0グッド

0クリップ

投稿2021/01/05 11:28

編集2021/01/05 12:55

自作のArticleコンポーネントにonClickを設定しているのに、Articleコンポーネント内で表示している文字列上でクリックしても
アラートが出ません。コメントアウトしてるh2タグ上の文字列をクリックしたときはアラートが出ます。
どのように解決するのでしょうか。ご教示お願いいたします。

import

1import Article from './Article.jsx' 2 3class Blog extends React.Component { 4 5 6 constructor(props) { 7 super(props); 8 this.onClickButton = this.onClickButton.bind(this); 9 } 10 11 render() { 12 return ( 13 <> 14 <Article onClick={this.onClickButton} /> 15 {/* <h2 onClick={this.onClickButton}>onclick_test</h2> */} 16 </> 17 ) 18 } 19 onClickButton = () => { 20 alert('click') 21 }; 22 23} 24 25export default Blog

Article.jsx

import React from 'react' const Article = (props) => { return ( <> <h2>Article compornent</h2> </> ) } export default Article

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

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

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

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

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

hoshi-takanori

2021/01/05 12:08

自作の Article コンポーネントのソースを見ないとなんとも言えません。 (Article コンポーネントのすべてのソースは不要ですが、最終的にどの HTML タグに onClick が設定されているかが問題です。)
退会済みユーザー

退会済みユーザー

2021/01/05 12:57

レスありがとうございます。 Article.jsxのソース追記しました。文字列をh2タグで囲っただけのものとなっています。 ただ少し変わったところといえばArticle コンポーネントはファンクショナルコンポーネントで作成されているという点でしょうか?
guest

回答1

0

Article が返す h2 要素に onClick を設定しましょう。

js

1const Article = (props) => { 2 return ( 3 <> 4 <h2 onClick={props.onClick}>Article compornent</h2> 5 </> 6 ) 7}

React のコンポーネントは JavaScript の中だけの存在で、ブラウザが実際に表示したり、イベントに反応したりするのはコンポーネントが返す h2 や div などの HTML 要素 (タグ) だけになります。ので、Article に onClick を設定してもそれだけでは何も起こらなくて、Article が返す h2 などに onClick を設定する必要があります。

投稿2021/01/05 13:38

hoshi-takanori

総合スコア7899

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問