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

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

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

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

JavaScript

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

jQuery

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

Q&A

解決済

2回答

492閲覧

【html・js】form内の2つのinputをそれぞれ初期化するボタンを作成したい

退会済みユーザー

退会済みユーザー

総合スコア0

HTML5

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

JavaScript

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

jQuery

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

0グッド

1クリップ

投稿2022/09/14 08:21

実現したいこと

htmlとJavaScript(jquery含む)の勉強中です。
form内のinputを個別に初期化するボタンを作成したいのですがうまくいきません。
どうしてもform全体を初期化する動きになってしまいます。
どのようにスクリプトを記述したらよいでしょうか?
jqueryを利用した解決方法でも構いません。よろしくお願いします。

イメージ説明

該当のソースコード

Html、JavaScript

1<!DOCTYPE html> 2<html lang="en" dir="ltr"> 3 <head> 4 <meta charset="utf-8"> 5 <title></title> 6 </head> 7 <body> 8 9 <h2>フォーム初期化</h2> 10 11 <form> 12 <p> 13 input1 14 <input id="text1" type="text" value="テキスト1の初期値" class="form-control"> 15 </p> 16 <p> 17 input2 18 <input id="text2" type="text" value="テキスト2の初期値" class="form-control"> 19 </p> 20 <p> 21 <button type="reset" onclick="init_action();">input1を初期化</button> 22 <button type="reset" onclick="init_action();">input2を初期化</button> 23 </p> 24 </form> 25 </body> 26 27 <script type="text/javascript"> 28 function init_action(){ 29 //ここに何を記述???? 30 } 31 </script> 32</html> 33

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

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

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

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

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

m.ts10806

2023/08/06 21:15

1年近く放置された状態で何の音沙汰もなく急に解決とされましたが、その後どうなって解決と至ったのでしょうか。可能な範囲で回答にコメントでフィードバックください。
guest

回答2

0

javascript

1<script> 2document.addEventListener('click', e=>{ 3 const t=e.target; 4 if(t.matches('[data-target]')){ 5 const target=document.querySelector(t.dataset.target); 6 target.value=target.getAttribute('value'); 7 } 8}); 9</script> 10 11<form> 12<p> 13input1 14<input id="text1" type="text" value="テキスト1の初期値" class="form-control"> 15</p> 16<p> 17input2 18<input id="text2" type="text" value="テキスト2の初期値" class="form-control"> 19</p> 20<p> 21<button type="button" data-target="#text1">input1を初期化</button> 22<button type="button" data-target="#text2">input2を初期化</button> 23</p> 24</form>

投稿2022/09/14 09:03

yambejp

総合スコア114779

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

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

yambejp

2022/09/14 09:04

あら、ほとんどm.ts10806さんと被ってますね
guest

0

ベストアンサー

そもそもtype=resetの時点で所属するフォーム内の入力コントロールをクリアするので、
type=buttonとかに変更しといたほうが良いです。

それらを踏まえてパッと思いつくのは以下2パターン
・引数に識別子を与えて識別子を元にクリア処理
・data属性で対象ID設置してその属性値を元にクリア処理

いずれも「法則を見つける」「なければ法則を自分で作る」ことです。

後者の例(実装イメージ。未検証です。)

HTML

1<button type="button" class="clearbtn" data-target="#text1">input1を初期化</button> 2<button type="button" class="clearbtn" data-target="#text2">input2を初期化</button>

JavaScript

1$(function(){ 2 $(document).on('click','.clearbtn',function(e){ 3 const target = $(e.currentTarget).data('target'); 4 $(target).val(''); 5 }) 6}) 7

※別にjQueryでなくても似たようにできますが、コードが短く済むので。

今後cheackboxとかradioとかもしたいなら、対象のtypeやtagも取得したうえで個別対応。

投稿2022/09/14 08:41

編集2022/09/14 08:43
m.ts10806

総合スコア80850

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問