微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 关闭并重新打开特定单词周围的标签

我需要关闭< span>在单词“hello”之前标记,并在单击按钮后重新打开它.

这是一个Fiddle

这是我的代码

<span class="border"> 
    border Hello border border
</span>
<div> 
    <span class="button">Style me !</span>
</div>

jQuery:

$('.button').click(function () {
    $('.border').each(function () {
        var t = $(this).text();
        var s = t.split('Hello').join('</span>Hello<span class="border">');
        $(this).html(s)
    });
});

单击.button后我输出的HTML输出是:

<span class="border"> 
    border Hello<span class="border"> border border
</span>

我想要的输出是:

<span class="border"> 
    border </span>Hello<span class="border"> border border
</span>

为什么.join函数不插入< / span>关闭标签

解决方法

您可以像字符串一样修改dom结构,但是您必须定位父元素,因为您无法插入部分元素
$('.button').click(function () {
    $('.border').each(function () {
        var t = $(this).parent().html();
        var s = t.split('Hello').join('</span>Hello<span class="border">');
        $(this).parent().html(s)
    });
});

FIDDLE

请注意,这适用于示例,但如果父级也有其他元素,它可能会导致问题,我强烈建议找到另一种方法来获得您正在寻找的结果,而不是关闭和打开中间的元素等.

编辑:

这是另一种方法,它不会影响父母,而且更加整洁.
它使用outerHTML来获取周围的标记,这样就不会插入部分元素,但是开始和结束标记都是传递的字符串的一部分

$('.button').click(function () {
    $('.border').each(function () {
        this.outerHTML = this.outerHTML.split('Hello').join('</span>Hello<span class="border">');
    });
});

FIDDLE

或者更整洁的jQuery版本

$('.button').click(function () {
    $('.border').prop('outerHTML',function(_,html) {
        return html.split('Hello').join('</span>Hello<span class="border">');
    });
});

FIDDLE

原文地址:https://www.jb51.cc/js/150602.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐