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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

Q&A

解決済

2回答

296閲覧

書いたテキストを貼り付ける機能を書いてみたんですが、うまくいかないので、教えてください。

kinsncn

総合スコア34

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

0グッド

0クリップ

投稿2021/07/25 13:38

編集2021/07/26 14:18

テキストエリアに書いた内容を、別場所(下のほう)に<p>で囲んで表示したいと思いまして、
以下通り書きましたが、うまくいかないですね、何が問題でしょうか? 教えてください。

HTML/Javascript

1<body> 2 <div id="test"> 3 <textarea id="text">これはテストです</textarea> 4 <button onclick ="postTxt()" id="add-btn">登録</button> 5 6 <div id="post"> 7 <!--<p>テキストが表示される</p>--> 8 </div> 9 </div> 10 11 <!-- Javascript --> 12 <script> 13 14 let text = document.querySelector('#text') 15 let post = document.querySelector('#post') 16 17 //HTML書き込む 18 function postTxt () { 19 if (text.value == 0) { 20 alert('入力してください。') 21 } else { 22 if (window.confirm ('登録しますか?')) { 23 post.appendChild(` 24 <p>${text.value}</P> 25 `) 26 } 27 } 28 } 29 </script> 30</body>

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

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

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

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

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

guest

回答2

0

ボタン押したときの情報を保持してない
とかですかね(何が起きたか書いてないので推測ですが)

関数実行前に得た情報なので実行時の情報は持っていません。
現在のコードだと画面表示時の情報のみ。
実行毎にオブジェクトを取得してください。

また、HTMLも一部なので一概には言えませんが、buttonの初期値はtype=submitなのでフォーム送信しないならtype=buttonを明示しておきましょう。

投稿2021/07/25 13:49

m.ts10806

総合スコア80875

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

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

kinsncn

2021/07/26 14:07

ありがとうございました。
guest

0

ベストアンサー

write()はdocument.write()と書いたと同じことになるので出力内容が空欄で上書きされてしまいます。
writeではなく、別の名前を使用した方が良いですね。

javascript

1 post.appendChild(` 2 <p>${text.value}</P> 3 `)

この部分は、jQueryのappendとは違いテキストではなくNodeを指定します。

javascript

1 let p = document.createElement("p") 2 p.textContent = text.value 3 post.appendChild(p) 4

投稿2021/07/25 14:07

cobm

総合スコア239

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

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

kinsncn

2021/07/26 14:20 編集

ありがとうございました。 やりたいことができましたので、非常に助かりました。ノード指定方式はうまくいきました。
kinsncn

2021/07/26 14:21 編集

追加で教えてください。 上のコードを以下のコードを使い、ご指摘通り修正しましたが、うまく動かないですね、どこがおかしいでしょうか? post.appendChild(` <p>${text.value}</P> `)
cobm

2021/07/26 14:55 編集

appendChildの中はテキストではなくNodeですね。 ``` <body> <div id="test"> <textarea id="text">これはテストです</textarea> <button onclick ="postTxt()" id="add-btn">登録</button> <div id="post"> <!--<p>テキストが表示される</p>--> </div> </div> <!-- Javascript --> <script> let text = document.querySelector('#text') let post = document.querySelector('#post') //HTML書き込む function postTxt() { if (text.value == 0) { alert('入力してください。') } else { if (window.confirm ('登録しますか?')) { let p = document.createElement("p") p.textContent = text.value post.appendChild(p) } } } </script> </body> ``` 文字列で指定したい場合は、innerHTMLを使います。 ``` post.innerHTML += `<p>${text.value}</p>` ```
kinsncn

2021/07/28 12:49

ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問