(16) ボタン押下時にカーソル位置に文字列を挿入

ボタン押下により、textareaで編集中の文章のカーソル位置に、任意の文字列を挿入したい。
これをJavaScriptで実装する。

ほぼほぼこちらの内容を参考にさせていただいた。
http://qiita.com/noraworld/items/d6334a4f9b07792200a5

<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>

<script>
$(function(){
  $("a[name='option']").click(function(){
    var textarea = document.querySelector("textarea[name='bun']");
    var sentence = textarea.value;
    var len      = sentence.length;
    var pos      = textarea.selectionStart;
    var before   = sentence.substr(0, pos);
    var word     = $(this).text();
    var after    = sentence.substr(pos, len);
    sentence = before + word + after;
    textarea.value = sentence;
    return false;
  });
});
</script>

</head>
<body>

<textarea name="bun" style="width:100%;height:10rem"></textarea>

<a name="option" href="">[山田さん]</a>
<a name="option" href="">[加藤さん]</a>
<a name="option" href="">[岡本さん]</a>

</body>
</html>

サンプルはこちらです。
//hp.dogrow.net/sample/00016/


コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です