作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这段代码,我只是想了解为什么我需要在开始时使用 removeAllRanges
。 sel 是否在初始化时自动包含范围?
function setCaret(boolean_position) {
var range = document.createRange();
var sel = window.getSelection();
range.selectNodeContents($('#board_code')[0]);
range.collapse(boolean_position);
sel.removeAllRanges();
sel.addRange(range);//setting the caret position
}
最佳答案
是的,从 window.getSelection()
检索的选择不是像 document.createRange()
创建的范围那样的空实例。请注意这些方法名称的区别 - 一个创建新实例,第二个获取实例。
原因很简单——您可以有多个范围实例,每个实例包含不同的位置。但是每个文档只有一个选择。
因此,在添加范围之前,通常您必须删除当前选择的旧范围。当然,除非您想扩展当前选择。
更新:正如 Tim 正确指出的那样,只有 Firefox 支持多个选择范围。这意味着只有在 Firefox 上,您才能一次选择多个 DOM——例如您可以选择表格的列或使用 CTRL 键添加更多选择。
因此,只有 Firefox 要求您在添加下一个之前执行 removeAllRanges()
。其他浏览器会自动删除旧范围。
关于javascript - 为什么在选择开始时使用 removeAllRAnges()?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16933301/
我有这段代码,我只是想了解为什么我需要在开始时使用 removeAllRanges。 sel 是否在初始化时自动包含范围? function setCaret(boolean_position) {
我正在使用 node-webkit (Chromium 38.0.2125.104) 开发一个 markdown 编辑器,在输入时将 markdown 转换为 html,并在相同的 contented
我是一名优秀的程序员,十分优秀!