我有一个contenteditable div
,我需要知道当前插入符号处的单词。我试过this solution,但问题是,它不识别特殊字符,如@
和~
。所以,如果一个词开始~
,如~fool
,我得到fool
,而我预计~fool
。所以我试图修改解决方案,考虑到如果将选择移回后,遇到的角色不是空格,我会继续向后移动,直到遇到空格。这将使选择的开始。同样,我会继续前进直到找到空间,这将标志着选择的结束。然后选择会给我这个词。为了得到插入位置,我使用了this solution。结合起来,我的代码现在看起来像这样:在contenteditable div中获取以特殊字符开头的单词在插入符号处的词
function getCaretPosition(editableDiv) {
var caretPos = 0,
sel, range;
if (window.getSelection) {
sel = window.getSelection();
if (sel.rangeCount) {
range = sel.getRangeAt(0);
if (range.commonAncestorContainer.parentNode == editableDiv) {
caretPos = range.endOffset;
}
}
} else if (document.selection && document.selection.createRange) {
range = document.selection.createRange();
if (range.parentElement() == editableDiv) {
var tempEl = document.createElement("span");
editableDiv.insertBefore(tempEl, editableDiv.firstChild);
var tempRange = range.duplicate();
tempRange.moveToElementText(tempEl);
tempRange.setEndPoint("EndToEnd", range);
caretPos = tempRange.text.length;
}
}
return caretPos;
}
function getCurrentWord() {
var sel, word = "";
if (window.getSelection && (sel = window.getSelection()).modify) {
var selectedRange = sel.getRangeAt(0);
sel.collapseToStart();
sel.modify("move", "backward", "word");
while (sel.toString() != " " && getCaretPosition($("#editor").get(0)) != 0) {
sel.modify("move", "backward", "character");
(sel = window.getSelection()).modify;
}
sel.modify("move", "forward", "character");
sel.modify("extend", "forward", "word");
word = sel.toString();
// Restore selection
sel.removeAllRanges();
sel.addRange(selectedRange);
} else if ((sel = document.selection) && sel.type != "Control") {
var range = sel.createRange();
range.collapse(true);
range.expand("word");
word = range.text;
}
return word;
}
$(function() {
$(document).on('keyup keydown paste cut mouseup',"#editor", function() {
var word = getCurrentWord();
console.log(word);
});
});
但是,这根本不起作用。这是问题没有。 1.问题2是,即使图片中有图像,用户点击图片,图片处理程序不断返回最后一个图片,但我期待空白字符串。任何人都可以帮我解决这两个问题吗?
我不想成为那个人,但它听起来像2个回答你有你需要放在一起工作解决方案为您的需要的一切之间。你不必标记任何一个答案是对的,只是认为你有足够的解决方案来为自己工作:P –
我也在自己尝试一些东西,我不是懒洋洋地坐在别人的工作解决方案上。 – SexyBeast
我的歉意,我并没有打算暗示你是懒惰的。只是意味着这两个答案之间我认为答案是潜伏的。 –