gpt4 book ai didi

javascript - 使用 rangy 库获取所选文本的父节点

转载 作者:数据小太阳 更新时间:2023-10-29 04:39:08 33 4
gpt4 key购买 nike

我正在使用 rangy库,并且可以选择内容中的文本,如下所示:

var sel = rangy.getSelection();
alert(sel);

我不知道如何获取选定的文本父节点/元素。例如,如果我选择的文本是

<strong>My Text</strong> 
or
<h1>My Title</h1>

我怎样才能同时包含强节点或 H1 元素?

最佳答案

sel.anchorNode.parentNode 将为您提供仅包含选择的一端的节点的父节点。要获取整个选择的最内层包含元素,最简单的方法是从选择中获取一个范围并查看其 commonAncestorContainer 属性(它可能是一个文本节点,在这种情况下您需要获取它的父级):

var sel = rangy.getSelection();
if (sel.rangeCount > 0) {
var range = sel.getRangeAt(0);
var parentElement = range.commonAncestorContainer;
if (parentElement.nodeType == 3) {
parentElement = parentElement.parentNode;
}
}

关于javascript - 使用 rangy 库获取所选文本的父节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10560155/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com