
お世話になります。JS初心者です。
jsで、「要素を追加し、ある文字が無いときは非表示にする」ということをしたいのですが、コンソールでは何のエラーは出ませんが、動作しません。
ちなみに、
functionを取ったり、16行目の下(let htmlstrApper〜)に
htmlstr.style.display = "none"; を入れると、 style undefined でエラーになります。
一体どこが悪いのでしょうか?
どなたか、ご教授のほど、どうぞ宜しくお願い致します。
<html>
<body>
<div>
<div class="itemDescription">
<p>テストです。テストです。</p>
<div class="buttonA">
<button type="submit" style="display: block;">ボタン</button>
</div>
</div>
</div>
<script>
function htmlstrCkbtnApper(){
let itemDescription = document.querySelector(".itemDescription").innerText;
let buttonA = document.querySelector(".buttonA");
const htmlstr = '<p style="color:red;font-weight:bold">追加の説明文あああ</p>';
let htmlstrApper = buttonA.insertAdjacentHTML('beforebegin',htmlstr);
if(itemDescription.match(/いいい/) ) {
htmlstr.style.display = "block";
}else{
htmlstr.style.display = "none";
}
}
</script>
</html>
No.1ベストアンサー
- 回答日時:
こんばんは
>コンソールでは何のエラーは出ませんが、動作しません。
ご提示の状態では、関数定義がされているだけの状態なので、実行はされません。
ロードしたときに実行したければ、
htmlstrCkbtnApper(); // 関数を実行させる。
を入れておくとか。
ボタンを押した際に実行するなら、
document.querySelector('.buttonA button').addEventListener('click', ()=>{
htmlstrCkbtnApper();
});
等として、実行させるなど。
想像するところ、一度だけ実行すれば良さそうですが、上記の記述だと、ボタンを押すたびに関数が呼び出されるので、何度でも繰り返してしまいますのでご注意。
>style undefined でエラーになります。
そこは、勘違いが原因ではないかと思われます。
変数 htmlstr は文字列として定義されていますので、styleプロパティはありません。
それなので、エラーになっています。
表示のstyleを設定したければ、DOM要素を取得して設定すれば可能と思います。
早速のご回答ありがとうございます。
できました!
呼び出し忘れてるとか、もう、恥ずかしい限りのミスで申し訳御座いません。
htmlstrに、divのidつけて、DOM要素を取得したら、思っていた通りの挙動ができました。
>変数 htmlstr は文字列として定義されていますので、…
確かに、おっしゃる通り、文字列ですね。これにstyleなんて効くわけないですよね…。そんなことにも気づけない悲しさ。
上記のように設定したら、functionは不要になりましたので^^;、それも消して実行させることにしました。
本当にありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript clear機能を失わずにファイルアップロード機能を作成したい 3 2023/06/10 16:12
- JavaScript vertical sliderをautoplayしたい 2 2022/08/25 14:47
- JavaScript jqueryを使ったスムーススクロールのコードを書いたのですが、HTMLコード内にある、a butt 2 2022/04/14 10:59
- JavaScript アップロードファイルの種類によって処理を分岐させたいのですが書き方が分からずアドバイスお願いします 4 2023/06/17 19:12
- HTML・CSS CSSが効かずどのように指定すれば良いか分からないのでアドバイスお願い致します 2 2023/06/07 12:25
- HTML・CSS CSS のみのタブ切り替えについて 1 2023/01/11 16:47
- HTML・CSS アコーディオンメニューが思うように動作しません。 1 2023/08/20 16:48
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Eclipse(JAVA)のデバッグで他...
-
エクリプスで実行時、最新クラ...
-
「ワークスペースをビルド中」...
-
Javascriptの値をJava(JSP)へ渡...
-
コミット前の更新データをチェ...
-
JAVAにのeclipseに関する質問で...
-
split関数で区切り文字がない場合
-
VB実行中に一つ前の動作に戻る機能
-
Spyder上のPythonでinputが実行...
-
javascriptで、style undefined...
-
jdbcでinsert,delete,createをe...
-
eclipseが使えません
-
eclipseで「サーバーで実行」表...
-
eclipseのjavaを実行できない
-
Javascriptのパーミッション
-
powershellのWin32_NetworkAdap...
-
ダブルクォートがエスケープで...
-
コマンドライン引数の掛け算の...
-
Eclipse 実行→Javaアプリケー...
-
環境変数設定で
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「ワークスペースをビルド中」...
-
split関数で区切り文字がない場合
-
eclipseでスタックサイズを変更...
-
Eclipse(JAVA)のデバッグで他...
-
Javascriptの値をJava(JSP)へ渡...
-
コミット前の更新データをチェ...
-
JAVAにのeclipseに関する質問で...
-
Javaで年月の取得(YYYYMM形式で)
-
エクリプスで実行時、最新クラ...
-
Eclipse 実行→Javaアプリケー...
-
Eclipseで実行>Javaアプリケー...
-
javascriptで、style undefined...
-
jdbcでinsert,delete,createをe...
-
Javascriptのパーミッション
-
jasper.exceptionとは?
-
JUnit コードカバレッジについて
-
jarsigner 署名確認について
-
バイナリーコードと、ソースコ...
-
JAVAでアプレットのエラー(ecl...
-
環境変数設定で
おすすめ情報