账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    getSelection().getRangeAt(0)获取contenteditable="true"的div的光标不准
    43
    0

    用contenteditable="true"的div去模拟textarea标签
    使用getSelection().getRangeAt(0)获取当前光标的位置
    然后在这个位置插入文字
    可是得到的startOffset不准确
    发现Selection对象的Node并不是contenteditable="true"的div
    而是最后一次鼠标点击的元素,怎么使用js去修改Selection对象对应的Node呢?

    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 11 元积分
        全部回答
    • 0
    • 独自上岸自我救赎 普通会员 1楼

      这个问题可能是由于光标在div的某个部分过于深入或过于浅出,导致选择区的范围出现问题。以下是几种可能的解决方案:

      1. 调整div的宽度:你可以通过调整div的宽度来调整其内容的可见范围。你可以使用CSS的width属性来设置div的宽度。

      css div { width: 100px; }

      1. 使用CSS的:hover伪类:你可以在div的内容上添加:hover伪类,这样当鼠标悬停在div上时,div的内容会变得更加可见。

      css div { width: 100px; } div:hover { display: block; }

      1. 使用JavaScript:你可以使用JavaScript来监听div的内容变化,然后调整div的可见范围。

      javascript div.addEventListener('change', function() { var content = div.innerText; var visibleRange = document.createRange(); visibleRange.selectNodeContents(this); visibleRange.collapse(false); var start = visibleRange.startContainer; var end = visibleRange.endContainer; var startOffset = start.offsetLeft; var endOffset = end.offsetLeft; div.style.width = startOffset + 'px' + endOffset + 'px'; });

      1. 使用CSS的z-index属性:你可以使用CSS的z-index属性来调整div的可见位置。如果div的z-index设置得较高,那么其他元素可能覆盖它的内容,导致光标在div的某个部分过于深入或过于浅出。你可以通过设置div的z-index设置得较低,然后调整其他元素的z-index,来解决这个问题。
    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部