[javascript]テキストエリアのカーソル位置に挿入・選択範囲をタグで囲う
テキストエリアのカーソル位置に挿入・選択範囲をタグで囲う
まずは選択範囲を無視して現在のテキストエリアのカーソルの位置に挿入するようにしてみます。<html>
<body>
<script>
function insert(str) {
let input = document.getElementById('text_area');
//テキストエリアに入力されている文字数
let length = input.length;
let position = text_area.selectionStart;
let before = input.value.substring(0, position);
let after = input.value.substring(position, input.length);
input.value = before + str + after;
}
</script>
<textarea id="text_area" rows="5" cols="40">あいうえおかきくけこさしすせそ</textarea>
<button type="button" onclick="insert('[ABC]')">カーソル位置に[ABC]を挿入</button>
</body>
</html>
次に選択範囲も考慮して挿入やタグなどで囲うようにしてみます。
<html>
<body>
<script>
function insert(str) {
let input = document.getElementById('text_area');
let input_length = text_area.value.length;
let select_1 = text_area.selectionStart;
let select_2 = text_area.selectionEnd;
//選択範囲より前
let before = text_area.value.substring(0, select_1);
//選択範囲より後
let after = text_area.value.substring(select_2, input_length);
//選択範囲
let select_value = text_area.value.substring(select_1, select_2);
if (str.match(/\?/)) {
select_value = str.replace(/\?/g, select_value);
} else {
select_value = str;
}
text_area.value = before + select_value + after;
}
</script>
<textarea id="text_area" rows="5" cols="40">あいうえおかきくけこさしすせそ</textarea>
<button type="button" onclick="insert('[ABC]')">選択範囲に[ABC]を挿入</button>
<button type="button" onclick="insert('[[?]]')">選択範囲を[[と]]で囲む</button>
</body>
</html>
ページ情報
| タイトル | [javascript]テキストエリアのカーソル位置に挿入・選択範囲をタグで囲う |
| URL | https://www.nomuramath.com/tjw53eoc/ |
| SNSボタン |
行列式と行・列の入れ替え
\[
\det\left(\boldsymbol{a}_{\tau\left(1\right)},\boldsymbol{a}_{\tau\left(2\right)},\cdots,\boldsymbol{a}_{\tau\left(n\right)}\right)=\sgn\left(\tau\right)\det\left(\boldsymbol{a}_{1},\boldsymbol{a}_{2},\cdots,\boldsymbol{a}_{n}\right)
\]
不変部分空間の定義と性質
\[
f\left(W\right)\subseteq W
\]
ベクトル空間の和・直和・和集合・積集合・直積の定義と基本性質
\[
V_{1}+V_{2}=\left\{ \boldsymbol{v}_{1}+\boldsymbol{v}_{2};\boldsymbol{v}_{1}\in V,\boldsymbol{v}_{2}\in V\right\}
\]
内積の連続性
\[
\lim_{k\rightarrow\infty}\left\langle \boldsymbol{x}_{k},\boldsymbol{y}_{k}\right\rangle =\left\langle \boldsymbol{x},\boldsymbol{y}\right\rangle
\]

