マウスがクリックされたときに、その位置にあるコンテンツ編集可能なdivから1つの単語を抽出しようとしています。例えば:
Lorem ipsum dolorはアメットに座り、cons |ecteturadipiscingエリート。Crasvestibulumgravidatincidunt。Proin justo dolor、iaculis vulputate eleifend et、facilisiseuerat。*
|を使用する カレットを表すには、関数は「consectetur」を返す必要があります。
私のコード:
window.onload = function () {
document.getElementById("text-editor").onclick = function () {
var caretPos = 0, containerEl = null, sel, range;
if (window.getSelection) {
sel = window.getSelection();
if (sel.rangeCount) {
range = sel.getRangeAt(0);
if (range.commonAncestorContainer.parentNode == this) {
caretPos = range.endOffset;
}
}
} else if (document.selection && document.selection.createRange) {
range = document.selection.createRange();
if (range.parentElement() == this) {
var tempEl = document.createElement("span");
this.insertBefore(tempEl, this.firstChild);
var tempRange = range.duplicate();
tempRange.moveToElementText(tempEl);
tempRange.setEndPoint("EndToEnd", range);
caretPos = tempRange.text.length;
}
}
var prevSpace, nextSpace, text = this.innerText;
prevSpace = text.substring(0,caretPos).lastIndexOf(" ");
nextSpace = text.indexOf(" ", caretPos + 1);
nextSpace == -1 ? nextSpace = text.length - 1 : false;
prevSpace++;
console.log([prevSpace,caretPos,nextSpace].join("|"));
var word = text.substring(prevSpace, nextSpace);
//Removes punctuation and whitespace.
var patt = new RegExp("([A-Za-z0-9']*)","g");
word = patt.exec(word)[0];
document.getElementById("current-word").innerHTML = word;
};
};
関数は、contenteditable divのマウスクリックイベントにバインドされます。このイベントは、キャレット位置を計算し、前後のスペース文字(または文字列の最初または最後)のインデックスを検索し、サブ文字列を使用して単語を決定します。句読点と空白を削除するための迅速な正規表現の一致があり、最終的に正しい単語になります。
これは、contenteditable div内に単一のテキストノードがある場合は正常に機能しましたが、タグやその他のさまざまなタグを削除し始めるとすぐに、キャレット位置を計算するメソッドの一部が機能しなくなり、常に0と計算されました。テキストの場合と同じように、HTMLでカレットの位置を計算する方法はありますか?
そうでない場合、誰かが別の方法を提案できますか?