如何在输入新行时获得插入符号在contentEditable div中的位置?

时间:2013-04-26 02:45:25

标签: javascript iphone html uiwebview contenteditable

我正在使用UIWebview创建一个富文本编辑器,它使用contentEditable div。我想以像素为单位得到插入符号的位置。我搜索了很多,我得到了下面的代码。

function getCaretClientPosition() {
  var x = 0, y = 0;
  var sel = window.getSelection();
  if (sel.rangeCount) {
    var range = sel.getRangeAt(0);
    if (range.getClientRects) {
      var rects = range.getClientRects();
      if (rects.length > 0) {
        x = rects[0].left;
        y = rects[0].top;
      }
    }
  }
  return { x: x, y: y };
}

上面的代码运行良好,直到我输入换行符。 sel.getRangeAt(0)返回null,因此函数无法返回正确的插入符Y像素。

2 个答案:

答案 0 :(得分:5)

这是我用来通过插入临时对象并删除它来获取插入符号顶部位置的代码:

function getCaretTopPosition() {
    document.execCommand('insertHTML', false, '<span id="hidden"></span>');
    var hiddenNode = document.getElementById('hidden');
    if (!hiddenNode) {
        return 0;
    }
    var topPosition = hiddenNode.offsetTop;
    hiddenNode.parentNode.removeChild(hiddenNode);
    return topPosition;
}

答案 1 :(得分:1)

此解决方案修复了WebKit中的newLine问题。

function getCaretClientPosition() {
    var x = 0, y = 0;
    var sel = window.getSelection();
    if (sel.rangeCount) {

        var range = sel.getRangeAt(0);
        var needsToWorkAroundNewlineBug = (range.startContainer.nodeName.toLowerCase() == 'p'
                                           && range.startOffset == 0);

        if (needsToWorkAroundNewlineBug) {
            x = range.startContainer.offsetLeft;
            y = range.startContainer.offsetTop;
        } else {
            if (range.getClientRects) {
                var rects = range.getClientRects();
                if (rects.length > 0) {
                    x = rects[0].left;
                    y = rects[0].top;
                }
            }
        }
    }
    return { x: x, y: y };
}