JavaScriptでテキストボックスの値を取得/設定するサンプルです。
目次
textbox | テキストボックスの値を取得する |
テキストボックスに値を設定する | |
action | 移動時に値を取得する |
フォーカスを当てる/外す(focus/blur) | |
全選択にする/外す(select/blur) | |
値をコピーする(document.execCommand("copy")) | |
書き込み不可/可にする(disabled) |
テキストボックスの値を取得する
ボタンを押すとテキストボックスの値を取得し画面に表示します。値の変更も可能です。
取得した値
上記サンプルのコード
<p>取得した値 <span id="span1"></span></p>
<input type="text" value="red" id="text1" maxlength="5" />
<input type="button" value="ボタン" onclick="clickBtn1()" />
<script>
function clickBtn1() {
const t1 = document.getElementById("text1").value;
document.getElementById("span1").textContent = t1;
}
</script>
3行目は、「input type="text"」があるのでテキストボックスです。
4行目は、「input type="button"」があるのでボタンです。
ボタンをクリックすると「onclick="clickBtn1()"」により7行目の関数が実行されます。
8行目は、getElementByIdメソッドで3行目の「id="text1"」のtext1を指定し、.valueで「value="red"」のredを取得し変数「t1」にセットします。
getElementByIdの構造
変数 = document.getElementById(idの値).value; |
getElementByIdは、場所(idの値)を指定し入力値(value値)を取得します。
9行目は、変数「t1」の値を1行目の「id="span1"」の箇所に表示します。
Idを指定しない場合
getElementByIdでIdを指定しない場合は、フォームとnameを指定します。
<p>取得した値 <span id="span1"></span></p>
<form name="form1">
<input type="text" name="text1" value="red" maxlength="5" />
</form>
<input type="button" value="ボタン1" onclick="clickBtn1()" />
<script>
function clickBtn1() {
const t1 = document.form1.text1.value;
document.getElementById("span1").textContent = t1;
}
</script>
9行目は、2行目のフォームのname「form1」と3行目のテキストボックスのname「text1」で対象を特定(3行目)し、そのvalueから値を取得し変数「t1」に代入します。
テキストボックスに値を設定する
ボタンを押すとテキストボックスに値を設定します。
上記サンプルのコード
<label for="text2">入力欄:</label>
<input type="text" value="red" id="text2" maxlength="5" />
<input type="button" value="ボタン" onclick="clickBtn2()" />
<input type="button" value="クリア" onclick="clickBtn3()" />
<script>
function clickBtn2() {
document.getElementById("text2").value = "blue";
}
function clickBtn3() {
document.getElementById("text2").value = "";
}
</script>
2行目は、「input type="text"」があるのでテキストボックスです。
3行目は、「input type="button"」があるのでボタンです。
ボタンをクリックすると「onclick="clickBtn2()"」により7行目の関数が実行されます。
8行目は、getElementByIdメソッドで2行目のID「text2」を指定し、valueの値に"blue"をセットしています。
getElementByIdの構造
document.getElementById(idの値).value = 値; |
getElementByIdメソッドで場所(idの値)を指定しvalueに値を設定します。
11行目は、空文字("")をセットすることによりテキストボックスをクリアします。
Idを指定しない場合
getElementByIdでIdを指定しない場合は、フォームとnameを指定します。
<form name="form2">
<input type="text" name="text2" value="red" maxlength="5" />
</form>
<input type="button" value="ボタン1" onclick="clickBtn3()" />
<script>
function clickBtn3() {
document.form2.text2.value = "blue";
}
</script>
8行目は、1行目のフォームのname「form2」と2行目のテキストボックスのname「text2」で対象を特定(2行目)し、そのvalueの値に"blue"を代入しています。
移動時に値を取得する
テキストボックスに値を入力し、Enterキーを押すまたはカーソルを移動するとテキストボックスの値を取得し画面に表示します。
取得した値
上記サンプルのコード
<p>取得した値 <span id="span3"></span></p>
<input type="text" value="red" id="text3" maxlength="10" />
<script>
const text3 = document.getElementById("text3");
text3.addEventListener("change", changeText);
function changeText() {
document.getElementById("span3").textContent = text3.value;
}
</script>
7行目は、addEventListenerで対象にchangeイベントが発生した時、9行目のchangeTextの関数を実行します。
フォーカスを当てる/外す(focus/blur)
上記サンプルのコード
<input type="text" value="red" id="textfoc" maxlength="5" />
<input type="button" value="ボタンon" onclick="clickBtnFoc()" />
<input type="button" value="ボタンoff" onclick="clickBtnBlr()" />
<script>
function clickBtnFoc() {
const t1 = document.getElementById("textfoc");
t1.focus();
}
function clickBtnBlr() {
const t1 = document.getElementById("textfoc");
t1.blur();
}
</script>
8行目のfocusは、フォーカスを当てます。
12行目のblurは、フォーカスを外します。
全選択にする/外す(select/blur)
上記サンプルのコード
<input type="text" value="red" id="textsel" maxlength="5" />
<input type="button" value="ボタンon" onclick="clickBtnSel()" />
<input type="button" value="ボタンoff" onclick="clickBtnBlr2()" />
<script>
function clickBtnSel() {
const t1 = document.getElementById("textsel");
t1.select();
}
function clickBtnBlr2() {
const t1 = document.getElementById("textsel");
t1.blur();
}
</script>
8行目のselectは、値を全選択にします。
12行目のblurは、値の全選択を外します。
値をコピーする(document.execCommand("copy"))
値を全選択してコピーします。値はテキスト等に貼り付けできます。
上記サンプルのコード
<input type="text" value="red" id="textcopy" maxlength="5" />
<input type="button" value="ボタンon" onclick="clickBtnCopy()" />
<script>
function clickBtnCopy() {
const t1 = document.getElementById("textcopy");
t1.select();
var result = document.execCommand("copy");
}
</script>
7行目は、テキストボックスの値を全選択しています。
8行目は、選択した値をコピーしています。テキスト等にコピーした内容を貼り付けることができます。
書き込み不可/可にする(disabled)
上記サンプルのコード
<input type="text" value="red" id="textdis" maxlength="5" />
<input type="button" value="ボタン" onclick="clickBtnDisable()" />
<script>
function clickBtnDisable() {
const t1 = document.getElementById("textdis");
if (t1.disabled == false) {
t1.disabled = true;
} else {
t1.disabled = false;
}
}
</script>
8行目は、テキストボックスの書き込みを不可にしています。
関連の記事