2016-11-08 13 views
3

以前はユーザーのキャレットの位置を保存していたプレーンテキストエリアを回して、Chrome拡張機能を再度開いたときに返信しました。私は今テキストエリアを編集可能なdivに変更して、基本的なテキストフォーマットを使用できるようにしましたが、キャレット位置の保存は機能しません。編集可能なdivにキャレットの位置を保存するにはどうすればよいですか?

現在、テキスト領域内にキャレットの位置を格納する作業コードがありますが、編集可能なdiv内で動作するには、変更する必要があるかどうかを調べる必要があります。

(function($) { 
$.fn.caret = function(pos) { 
    var target = this[0]; 
    var isContentEditable = target.contentEditable === 'true'; 
    if (arguments.length == 0) { 
     if (window.getSelection) { 
      if (isContentEditable) { 
       target.focus(); 
       var range1 = window.getSelection().getRangeAt(0), 
        range2 = range1.cloneRange(); 
       range2.selectNodeContents(target); 
       range2.setEnd(range1.endContainer, range1.endOffset); 
       return range2.toString().length; 
      } 
      return target.selectionStart; 
     } 
     if (document.selection) { 
      target.focus(); 
      if (isContentEditable) { 
       var range1 = document.selection.createRange(), 
        range2 = document.body.createTextRange(); 
       range2.moveToElementText(target); 
       range2.setEndPoint('EndToEnd', range1); 
       return range2.text.length; 
      } 
      var pos = 0, 
       range = target.createTextRange(), 
       range2 = document.selection.createRange().duplicate(), 
       bookmark = range2.getBookmark(); 
      range.moveToBookmark(bookmark); 
      while (range.moveStart('character', -1) !== 0) pos++; 
      return pos; 
     } 
     return 0; 
    } 
    if (pos == -1) 
     pos = this[isContentEditable ? 'text' : 'val']().length; 
    if (window.getSelection) { 
     if (isContentEditable) { 
      target.focus(); 
      window.getSelection().collapse(target.firstChild, pos); 
     } else 
      target.setSelectionRange(pos, pos); 
    } else if (document.body.createTextRange) { 
     var range = document.body.createTextRange(); 
     range.moveToElementText(target); 
     range.moveStart('character', pos); 
     range.collapse(true); 
     range.select(); 
    } 
    if (!isContentEditable) 
     target.focus(); 
    return pos; 
} 
})(jQuery) 
+1

興味深い質問が、私は、これはとにかく拡張固有ではないと思います。 – Xan

答えて

1

このスニペット(フィドル、私はここにコピーしたthis answerにクレジット)を見てみましょう:

をこのコードは、のmouseupとキャレットの位置を再計算するからkeyupイベントをリッスンします。あなたはこれらのポイントにそれを保存することができます。

function getCaretCharacterOffsetWithin(element) { 
 
    var caretOffset = 0; 
 
    var doc = element.ownerDocument || element.document; 
 
    var win = doc.defaultView || doc.parentWindow; 
 
    var sel; 
 
    if (typeof win.getSelection != "undefined") { 
 
    sel = win.getSelection(); 
 
    if (sel.rangeCount > 0) { 
 
     var range = win.getSelection().getRangeAt(0); 
 
     var preCaretRange = range.cloneRange(); 
 
     preCaretRange.selectNodeContents(element); 
 
     preCaretRange.setEnd(range.endContainer, range.endOffset); 
 
     caretOffset = preCaretRange.toString().length; 
 
    } 
 
    } else if ((sel = doc.selection) && sel.type != "Control") { 
 
    var textRange = sel.createRange(); 
 
    var preCaretTextRange = doc.body.createTextRange(); 
 
    preCaretTextRange.moveToElementText(element); 
 
    preCaretTextRange.setEndPoint("EndToEnd", textRange); 
 
    caretOffset = preCaretTextRange.text.length; 
 
    } 
 
    return caretOffset; 
 
} 
 

 
var lastCaretPos = 10; 
 

 
function showCaretPos() { 
 
    /* You could store the position when you call this function */ 
 
    var el = document.getElementById("test"); 
 
    lastCaretPos = getCaretCharacterOffsetWithin(el); 
 
    var caretPosEl = document.getElementById("caretPos"); 
 
    caretPosEl.innerHTML = "Caret position: " + lastCaretPos; 
 
} 
 

 
function restoreCaretPos() { 
 
    var node = document.getElementById("test"); 
 
    node.focus(); 
 
    var textNode = node.firstChild; 
 
    var range = document.createRange(); 
 
    range.setStart(textNode, lastCaretPos); 
 
    range.setEnd(textNode, lastCaretPos); 
 
    var sel = window.getSelection(); 
 
    sel.removeAllRanges(); 
 
    sel.addRange(range); 
 
} 
 

 
document.getElementById("test").onkeyup = showCaretPos; 
 
document.getElementById("test").onmouseup = showCaretPos; 
 
document.getElementById("button").onclick = restoreCaretPos;
<div id="test" contenteditable="true">This is an editable div</div> 
 
<div id="caretPos">Caret position: 10</div> 
 
<input type="button" id="button" value="restore caret" />

+1

エクステンションをクリックして戻すと、divにオートフォーカスがあり、キャレットが表示されます(保存された場所で点滅)。 – Alex

+0

@Athiumは私の最新のスニペットを見てみましょう。私は復元ボタンを追加しました。 – jcuenod

関連する問題