这是一个简化的 contenteditable 编辑器,包含两行文本:
let button = document.querySelector("button");
button.addEventListener("click", modify);
function modify() {
let selection = window.getSelection();
selection.modify("move", "forward", 'line');
}
<div contenteditable>
<p>This is a line of text.</p>
<p>This is a second line of text.</p>
</div>
<button>Extend selection</button>
步骤:
- 将光标放在“This”之后的第一行
- 点击按钮
预期:光标移动到第一行的末尾。
实际:光标移动到第二行中间某处。我在 macOS 上使用 Chrome 128。
我不太清楚这种行为。规范 ( https://w3c.github.io/selection-api/#dom-selection-modify ) 也没有具体说明这种行为。
我的问题:
- 为什么在 Chrome 上给出的示例中光标会以这种方式移动?
- 还有其他方法可以让我把光标移动到 Chrome 上的行尾吗?
规范本身似乎还不太清楚每个粒度实际上意味着什么 - https://w3c.github.io/selection-api/#dom-selection-modify:
sentence
会让你到达你所给例子中的行尾 - 但从技术上讲,它会移动到下一个句子,所以只要你在第一行引入一个,它就不会再到达行末了。lineboundary
似乎可以把它放到你想要的位置,至少在 Chrome 中是这样。