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

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

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

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

2回答

5008閲覧

[jQuery]spanタグのテキストが変更された場合にイベントを発火させたいです。

tanakamaro

総合スコア13

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2021/06/14 00:32

前提・実現したいこと

<span class="change_span">ここが変更</span>
上記の「ここが変更」の部分が変わった際にイベントを発火させたいのですが、どのような方法がありますでしょうか?
以下ではイベントの発火をすることが出来ませんでした。
ご教授頂けると幸いです。
$('.change_span').change(function (){

}

発生している問題・エラーメッセージ

イベントが発火しない

該当のソースコード

$('.change_span').change(function (){ }

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答2

0

ベストアンサー

change()はフォームコントロールでしか使えません。
MutationObserversubtreeオプションcharacterDataオプションchildListオプションを利用することで可能です。

投稿2021/06/14 00:37

編集2021/06/14 01:44
int32_t

総合スコア21695

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

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

tanakamaro

2021/06/14 01:07

ありがとうございます! 試してみたのですが observer.observe(target, { characterData: true })の部分で Failed to execute 'observe' on 'MutationObserver': parameter 1 is not of type 'Node'. at (index):260 (anonymous) @ (index):260 のエラーが表示されます。。
int32_t

2021/06/14 01:28

target がspan要素になってないのでしょう。$('.change_span')[0] など試してみてください。
hope_mucci

2021/06/14 01:29

int32_tさん MutationObserverでオプションを{subtree: true, characterData: true}指定してobserveしてみましたがspan要素のテキストの変更に反応しません。 {childList: true} の設定であればテキストの変更でも反応しました。 {subtree: true, characterData: true}が有効になる場合はどんなケースがあるのでしょう?
int32_t

2021/06/14 01:43

あ、childListも必要ですね。ご指摘ありがとうございます。 subtreeとcharacterDataだけだと、Textノードの値が変更されたときだけ反応します。Textノードが入れ替えられたときは反応しません。
tanakamaro

2021/06/14 02:27

ありがとうございます! 無事実装することが出来ました! 助かりました。
guest

0

javascript

1<script> 2window.addEventListener('DOMContentLoaded', ()=>{ 3 const mo = new MutationObserver(r=>{ 4 console.log(r[0].removedNodes[0].nodeValue); 5 console.log(r[0].addedNodes[0].nodeValue); 6 }); 7 const target=document.querySelector('span'); 8 const opt = { 9 childList:true, 10 characterData:true, 11 characterDataOldValue:true, 12 }; 13 mo.observe(target, opt); 14 target.textContent="bbb"; 15}); 16</script> 17<span>aaa</span>

投稿2021/06/14 01:26

yambejp

総合スコア116724

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問