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

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

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

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

JavaScript

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

3回答

3295閲覧

onclickでクリック後の処理をしたいです。

Mario_11

総合スコア95

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

JavaScript

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2020/07/26 10:55

onclickでクリック後の処理を行いたいのですがうまくいかず質問させていただきました。

参考サイト

現在、下記の様にfor文でHTMLを出力していて、for文の一つ目はクリック後の処理(クリックされた!の表示)がされるのですが、二つ目以降はクリックしても何の変化もなしです。

html

1 {% for list in lists %} 2 <div class="col-lg-4"> 3 <div class="card"> 4 <div class="card-body"> 5 <p class="text-center">{{ list.name }}</p> 6 <img alt="" src="{{ list.image.medium.url }}"/> 7 <br> 8 <p class="text-center">{{ list.content }}</p> 9 <p class="text-center">有効期限:{{ list.deadline }}</p> 10 <div id="text-button"> 11 <p id="text">クリック</p> 12 </div> 13 </div> 14 </div> 15 </div> 16 {% endfor %} 17<script> 18 document.getElementById("text-button").onclick = function() { 19 document.getElementById("text").innerHTML = "クリックされた!"; 20 }; 21</script> 22

for文で行うときはjavascriptも何か変更させないといけないのでしょうか?
何かアドバイスいただきたいです。よろしくお願いいたします。

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

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

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

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

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

guest

回答3

0

そもそも、IDは重複不可です。

投稿2020/07/26 10:57

kyoya0819

総合スコア10429

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

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

0

ベストアンサー

asuchi0819さんがおっしゃっているように、同じid属性は1ページ内に一つしか存在してはいけないことになっています。

もし文法を無視して同一idの要素が文書内に複数存在する場合、getElementByIdは最初の要素を取得します。(element.id)
そのため、clickハンドラを追加する処理が最初の1つにしかされていないのです。

HTMLのボタンの部分を

<div class="text-button"> <p class="text">クリック</p> </div>

スクリプトを

<script> // text-buttonクラスを持つ要素の配列を取得、各要素をforEachでループ処理、elには各要素が順番にわたさ Array.from(document.getElementsByClassName("text-button")).forEach(function(el) { // 書き換え対象であるtextクラスを持つ要素を取得 var iel = el.getElementsByClassName("text")[0]; // clickイベントのリスナーを設定 el.addEventListener("click", function() { iel.innerText = "クリックされた!"; }); }); </script>

としてみてください。

  • class属性を使ってElementを取得する場合getElementsByClassNameメソッドを使います。Element**"s"**であることに注意してください。
  • getElementsByClassNameHTMLCollectionを返します。HTMLCollectionElementの配列のようなものです。
  • jsで配列の各要素にたいして何らかの処理を行う場合、forEachメソッドを使うのが一般的です。
  • しかし、HTMLCollectionはElementの配列のようなもので、厳密には配列ではありません。なのでforEachは使うことができません。
  • そこでArray.fromを使って、HTMLCollectionを配列に変換します。
  • よって、Array.from(document.getElementsByClassName("text-button"))は、documentからtext-buttonクラスを持つ要素のHTMLCollectionを取得し、それを配列に変換する = documentからtext-buttonクラスを持つ要素の配列を取得するという意味になります。
  • forEachメソッドには関数を渡します。渡した関数にはforEachによって配列の各要素が自動的に渡されます。(今回はtext-buttonクラスを持つElementが順番に1つずつ渡されます。これをelで受けています) 参考
  • 書き換える対象となるtextクラスを持つ要素を、getElementsByClassNameで取得します。getElementsByClassNameはたとえ取得した要素が1つでもHTMLCollectionとして返すので、最初の要素[0]を取得します。
  • el(text-button)に対してイベントリスナーを設定します。この例の場合は、el.onclick = function(){...}でも問題ありませんが、この書き方ではtext-buttonのonclickに既に別のイベントリスナーが設定されていた場合、上書きしてしまいます。el.addEventListener("click", function(){...})を使うと、上書きすることなく追加することができます。

注意点としては、

  • dsocument内の全てのtext-buttonクラスを持つ要素に処理を行うので、text-buttonクラスを持つ全く別の要素がdocument内にあった場合、例外になる可能性が高い。(その他の要素がtextクラスを持つ要素を子に持っていないとTypeErrorになります。)

投稿2020/07/26 12:58

SAKASHITA-Koki

総合スコア27

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

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

Mario_11

2020/07/27 10:56

詳しく解説していただきありがとうございます! できました
guest

0

こんなかんじの処理です

投稿2020/07/27 01:08

yambejp

総合スコア116724

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

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

yambejp

2020/07/27 01:08

<script> window.addEventListener('DOMContentLoaded', ()=>{ document.querySelectorAll(".text-button").forEach(x=>{ x.addEventListener('click',()=>{ x.parentNode.querySelector(".text").innerHTML = "クリックされた!"; }); }); }); </script> <div> <div class="text-button"> <p class="text">クリック</p> </div> </div> <div> <div class="text-button"> <p class="text">クリック</p> </div> </div> <div> <div class="text-button"> <p class="text">クリック</p> </div> </div>
yambejp

2020/07/27 01:09

クラスがまずそうならカスタムデータ(data-*)を利用してください
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問