我有<textarea>
元素并在其中创建范围:
- 通过创建新范围
document.createRange()
- 获取
<textarea>
via的唯一子节点textarea.childNodes[0]
range.setStart
通过和设置范围开始和范围结束range.setEnd
然后我打电话range.getBoundingClientRect()
:
let textarea = document.querySelector('textarea');
let node = textarea.childNodes[0];
let range = document.createRange();
range.setStart(node, 3);
range.setEnd(node, 5);
console.log(range.getBoundingClientRect());
<textarea>aa bb cc</textarea>
但我收到ClientRect
所有零字段的对象,即left = top = width = height = 0
. 为什么这些字段为零?
请注意,如果我<textarea>
用通常的 div 替换,一切正常:
let textarea = document.querySelector('div');
let node = textarea.childNodes[0];
let range = document.createRange();
range.setStart(node, 3);
range.setEnd(node, 5);
console.log(range.getBoundingClientRect());
<div>aa bb cc</div>