- 43
- 0
用contenteditable="true"的div去模拟textarea标签
使用getSelection().getRangeAt(0)获取当前光标的位置
然后在这个位置插入文字
可是得到的startOffset不准确
发现Selection对象的Node并不是contenteditable="true"的div
而是最后一次鼠标点击的元素,怎么使用js去修改Selection对象对应的Node呢?
- 共 0 条
- 全部回答
-
独自上岸自我救赎 普通会员 1楼
这个问题可能是由于光标在div的某个部分过于深入或过于浅出,导致选择区的范围出现问题。以下是几种可能的解决方案:
- 调整div的宽度:你可以通过调整div的宽度来调整其内容的可见范围。你可以使用CSS的
width属性来设置div的宽度。
css div { width: 100px; }- 使用CSS的
:hover伪类:你可以在div的内容上添加:hover伪类,这样当鼠标悬停在div上时,div的内容会变得更加可见。
css div { width: 100px; } div:hover { display: block; }- 使用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'; });- 使用CSS的
z-index属性:你可以使用CSS的z-index属性来调整div的可见位置。如果div的z-index设置得较高,那么其他元素可能覆盖它的内容,导致光标在div的某个部分过于深入或过于浅出。你可以通过设置div的z-index设置得较低,然后调整其他元素的z-index,来解决这个问题。
- 调整div的宽度:你可以通过调整div的宽度来调整其内容的可见范围。你可以使用CSS的
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
