首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >jQuery克隆节点错误

jQuery克隆节点错误
EN

Stack Overflow用户
提问于 2014-05-29 10:48:35
回答 2查看 4.5K关注 0票数 0

我必须检查'p‘元素是否包含一些文本,如果是这样,请创建另一个元素'span’,然后克隆'p‘元素并将其追加到'span’元素中,并将其替换为‘span’元素。但是,我得到了以下错误:

Uncaught :在‘Node’上执行'appendChild‘失败:新的子元素为null。

这是我的密码:

代码语言:javascript
运行
复制
if ($("p:contains('computer forensics is')")) {
            var highlight = document.createElement('span');
            highlight.className = 'highlight';
            highlight.style.backgroundColor = "red";
            highlight.id = "";
            highlight.setAttribute("title", "");
            var node = $("p:contains('computer forensics is')");
            var wordClone = node.clone(true);
            highlight.appendChild(wordClone);
            node.parentNode.replaceChild(highlight, node);
        }
EN

回答 2

Stack Overflow用户

发布于 2014-05-29 10:50:47

做这一行:

代码语言:javascript
运行
复制
var wordClone = node.clone(true);

这方面:

代码语言:javascript
运行
复制
var wordClone = node.clone(true)[0]; // now it is HTMLElement

您将jQuery对象与本机元素混合在一起。

而且,当可用时,我也不明白为什么要使用jQuery而不是

您可以在jQuery中重写大部分内容:

代码语言:javascript
运行
复制
if ($("p:contains('computer forensics is')").length) {
    var highlight = $('<span/>', {
        "class": "higlight",
        style: "background-color:red;"
    });
    var node = $("p:contains('computer forensics is')");
    var wordClone = node.clone(true);
    highlight.append(wordClone);
    node[0].parentNode.replaceChild(highlight, node);
}
票数 3
EN

Stack Overflow用户

发布于 2014-05-29 11:23:07

您不能在span中包含段落(无效的HTML()),但是假设您希望段落中包含跨段:

JSFiddle:http://jsfiddle.net/TrueBlueAussie/Kw3tj/2/

代码语言:javascript
运行
复制
$(function () {
    var $node = $("p:contains('computer forensics is')");
    if ($node.length) {
        var $highlight = $('<span/>', {
            "class": "highlight", 
            style: "background-color: red"
        });
        $highlight.html($node.html());
        $node.empty().append($highlight);
    }
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23931579

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档