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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

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

JavaScript

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

Q&A

解決済

1回答

456閲覧

テキストエリアに入力された文字列を、任意の場所に挿入したい

kings_of_king12

総合スコア33

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

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

JavaScript

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

1グッド

1クリップ

投稿2022/09/02 21:40

編集2022/09/03 00:04

前提

テキストエリアに入力した文字列を、別のテキストエリアに出力したいです。

実現したい動作

「ソース」テキストエリアに入力→「送信」ボタン押下→「ソース」を「変換後」テキストエリアに出力→「コピーする」ボタン押下→コピー完了

「ソース」は「変換後」のreplPointにreplace()で置き換えています。

発生している問題

「ソース」テキストエリアに入力された文字列は取得できているのですが、「変換後」テキストエリアに出力ができない状態です。

該当のソースコード

javascript

1<!DOCTYPE html> 2<html lang="ja"> 3 4<head> 5 <meta charset="UTF-8" /> 6 <meta http-equiv="X-UA-Compatible" content="IE=edge" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0" /> 8 <title>pset</title> 9 10 <style></style> 11</head> 12 13<body> 14 <form method="post" action=""> 15 <div> 16 <label for="etc">ソース</label><br> 17 <textarea id="etc" name="etc" rows="30" cols="100"></textarea> 18 </div> 19 <input type="submit" name="btn_submit" value="送信" /> 20 <input type="hidden" name="form_session" value="ta9galkjlsGJ==" /> 21 </form> 22 <br> 23 <label for="etc">変換後</label><br> 24 <textarea id="story" name="story" rows="30" cols="100"> 25aaa 26replPoint 27 </textarea> 28 29 30 <br /> 31 <button onclick="copy()">コピーする</button> 32 <script> 33 function copy() { 34 var text = document.getElementsByTagName("textarea")[1]; 35 36 text.select(); 37 document.execCommand("copy"); 38 } 39 40 let input_submit = document.querySelector("input[type=submit]"); 41 input_submit.addEventListener("click", function (e) { 42 // フォームの送信キャンセル 43 e.preventDefault(); 44 45 46 // 文字列置換 47 const rep = "replPoint" 48 let input_etc = document.getElementsByTagName("textarea")[0].value; 49 console.log(input_etc); 50 let allcont = document.getElementsByTagName("textarea")[1].value; 51 console.log(typeof allcont); 52 let resultText = allcont.replace(new RegExp(rep), input_etc); 53 console.log(resultText); 54 55 // 送信ボタン 56 let input_submit = document.querySelector("input[name=btn_submit]"); 57 // 非表示の項目(セッションの受け渡しなどで使用) 58 let input_hidden = document.querySelector("input[name=form_session]"); 59 }); 60 </script> 61</body> 62 63</html>

備考

// 文字列置換 const rep = "replPoint" let input_etc = document.getElementsByTagName("textarea")[0].value; console.log(input_etc); let allcont = document.getElementsByTagName("textarea")[1].value; console.log(typeof allcont); let resultText = allcont.replace(new RegExp(rep), input_etc); console.log(resultText);

上記がテキストエリアを取得して出力したいと思っているソースになります。

現状考えうる手法で記述しておりますので、効率的・簡略して記述できる場合その記述も教えていただきたいです。
よろしくお願いいたします。

退会済みユーザー👍を押しています

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

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

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

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

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

m.ts10806

2022/09/02 22:55

>「変換後」テキストエリアに出力ができない そもそもどこにも上記実現に向けて書かれたコードがないように見受けられます。 どの部分でそこを表現されているのでしょうか?
kings_of_king12

2022/09/03 00:02

// 文字列置換 const rep = "replPoint" let input_etc = document.getElementsByTagName("textarea")[0].value; console.log(input_etc); let allcont = document.getElementsByTagName("textarea")[1].value; console.log(typeof allcont); let resultText = allcont.replace(new RegExp(rep), input_etc); console.log(resultText); こちらが該当箇所となります。 input_etcが「ソース」に入力された文字列。 allcontが「変換後」に既にある文字列を入れた変数。 resultTextはinput_etcの文字列が、allcontの文字列"replPoint"をreplace()しています。 console.logで「ソース」の文字列、「変換後」の文字列どちらとも取得できているのですが、 変換後に出力する方法がわからず手詰まりな状態です。
m.ts10806

2022/09/03 00:22

あと、id振られてるならidで取得したほうが良いです。 番号固定だと変更に弱くなります。
guest

回答1

0

ベストアンサー

シンプルに値入れるだけでいいなら下のようにすればいいかと。

JavaScript

1let resultText = allcont.replace(new RegExp(rep), input_etc); 2console.log(resultText); 3 4document.getElementsByTagName("textarea")[1].value = resultText;//←追加

投稿2022/09/03 08:38

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問