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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

JavaScript

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

Q&A

解決済

2回答

950閲覧

jsのファイルが読み込まれていない

Hiromu94

総合スコア5

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

JavaScript

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

0グッド

0クリップ

投稿2020/08/19 03:32

イメージ説明

現在、「削除」ボタンを押したらconfimメソッド発動するjsファイルをコーディングしようと思っています。
1行目で、ここのページに飛んだら下記の内容の処理をする記述をしました。
3行目で削除ボタンの要素を取得し、4行目できちんと取れているか確認しました。(コンソールで確認、取得できています。)
6行目で、削除ボタンをクリックしたら下記の内容の処理をする記述をしました。
7行目で、6行目の動作ができているか確認。

すると、console.log("ok")がでない。
※コンソール一番上の「ok」は違うjsファイルのです。

そして、コンソール上に赤文字でエラー文がたくさん出ました。
元々、(
confirm.js:6 Uncaught TypeError: delBtn.addEventListener is not a function
at confirm.js:6)
のみ、初めから出ていました。

おそらく、初めから6行目のファンクションが読み込まれていないと思います。
3行目の要素は4行目でしっかりと取れていると確認済みなので、他に原因がわからないです。
手詰まり状態になりました。皆様からのアドバイスやご意見をお聞かせください!

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

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

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

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

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

guest

回答2

0

3行目の要素は4行目でしっかりと取れていると確認済み

いえ、getElementsByClassNameは「Elements」と複数形となっているように、要素の集合(配列のようなもの)を返します。直接addEventListenerはできません。

1個だけ取りたいのならdocument.querySelectorを使う、複数ありうるのならfor文などで回して全てにイベントをつけるなど、構造に応じた対応が必要です。

投稿2020/08/19 03:37

maisumakun

総合スコア146018

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

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

Hiromu94

2020/08/19 03:58

コメントありがとうございます。 「getElementsByClassNameは「Elements」と複数形となっているように、要素の集合(配列のようなもの)を返します。直接addEventListenerはできない」 と言う部分知らなかったです。勉強になりました! ありがとうございます!
guest

0

ベストアンサー

delBtnはクラスで取得していますが複数あるのでしょうか?
ひとつしかないなら
document.querySelector('.delBtn')
で指定してあげてください

投稿2020/08/19 03:35

編集2020/08/19 03:39
yambejp

総合スコア116724

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

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

yambejp

2020/08/19 03:38

getElementsByClassNameで得られるHTMLCollectionやNodeListなどは 複数を取得する前提になっており、それ自体のaddEventListenerメソッドは 存在しません
Hiromu94

2020/08/19 03:56

コメントありがとうございます! delBtnの要素は複数あるので、querySelectorAll('.delBtn')で取得しました。 そして、全ての要素に処理を加えたいのでforEach文で記述し、下記の画像のようにしました。 https://gyazo.com/199ad2df069e8c52113745fc15474c22 コンソール上で確認したらエラー分などは出ておらず、おそらくできたと思いますが、この書き方は現時点で間違いはないでしょうか?
yambejp

2020/08/19 04:52 編集

例示の画像ではオブジェクトを掴んでなくないですか? document.querySelectorAll('.delBtn').forEach(x=>{ x.addEventListener('click',()=>{ console.log('ok') }); あとソースを画像で付ける場合は並行してテキストでもつけてください
Hiromu94

2020/08/19 05:34

ご丁寧にありがとうございました! また、次回からはテキストも付けるように気をつけます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問