javascript - 在javascript中获取插入符号位置之前的最后一个字符

标签 javascript jquery autocomplete contenteditable caret

我即将在我的 contenteditable div 中集成 Facebook,如果我给出“$”和一些像“a”这样的字符,我需要一个自动建议,它应该在我的插入符附近弹出位置。

我需要知道如何在 IE 和其他浏览器的 JavaScript 中找出插入符号位置之前的最后一个字符。我可以访问 Jquery 库。

(function($) {
    $.fn.getCursorPosition = function() {
        var input = this.get(0);
        if (!input) return; // No (input) element found
        if ('selectionStart' in input) {
            // Standard-compliant browsers
            return input.selectionStart;
        } else if (document.selection) {
            // IE
            input.focus();
            var sel = document.selection.createRange();
            var selLen = document.selection.createRange().text.length;
            sel.moveStart('character', -input.value.length);
            return sel.text.length - selLen;
        }
    }
})(jQuery);

eg.
var caretPosition = $("#contenteditablediv").getCursorPosition();
var lastchar = getchar(caretposition -1);???

最佳答案

这是一个如何执行此操作的示例。它创建一个范围,该范围从可编辑元素的开头开始并紧接插入符号之前结束,获取范围的文本并返回该范围的最后一个字符。

演示:http://jsfiddle.net/MH5xX/

function getCharacterPrecedingCaret(containerEl) {
    var precedingChar = "", sel, range, precedingRange;
    if (window.getSelection) {
        sel = window.getSelection();
        if (sel.rangeCount > 0) {
            range = sel.getRangeAt(0).cloneRange();
            range.collapse(true);
            range.setStart(containerEl, 0);
            precedingChar = range.toString().slice(-1);
        }
    } else if ( (sel = document.selection) && sel.type != "Control") {
        range = sel.createRange();
        precedingRange = range.duplicate();
        precedingRange.moveToElementText(containerEl);
        precedingRange.setEndPoint("EndToStart", range);
        precedingChar = precedingRange.text.slice(-1);
    }
    return precedingChar;
}

var editableEl = document.getElementById("editable");
var precedingCharEl = document.getElementById("precedingChar");

function reportCharacterPrecedingCaret() {
    precedingCharEl.innerHTML = "Character preceding caret: " + getCharacterPrecedingCaret(editableEl);
}

editableEl.onmouseup = editableEl.onkeyup = reportCharacterPrecedingCaret;
<div contenteditable="true" id="editable">Here is some text. Please put the caret somewhere in here.</div>
<div id="precedingChar" style="font-weight: bold"></div>

关于javascript - 在javascript中获取插入符号位置之前的最后一个字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15157435/

相关文章:

Eclipse PyDev 完成挂起(再次)

javascript - 谷歌浏览器的 V8 引擎真的那么好吗?

javascript - 我有一个函数设置为 onClick 事件,它将一组数据发送回 API

javascript - 如何在javascript或jquery中仅检测浏览器关闭按钮事件,无页面刷新等

javascript - 如何从 iframe 将元素附加到父主体?

javascript - JQGrid 和 JQuery 自动完成

jquery-ui - jQuery ui 自动完成组合框下拉位置

javascript - 基于动态参数过滤数组

javascript - 合并维护所有属性的对象数组

jquery - 在 Ajax 调用期间保持 ASP.Net session 处于事件状态