首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何仅打印outerHTML

如何仅打印outerHTML
EN

Stack Overflow用户
提问于 2014-04-22 22:06:01
回答 4查看 1.2K关注 0票数 1

我只想打印outerHTML,而不想打印innerHTML。我如何才能做到这一点?

示例HTML:

代码语言:javascript
复制
<div id="one">
    <div id="two">
        <div id="three">
            <div id="four">
            <div>
        </div>
    </div>
</div>

所需输出:

代码语言:javascript
复制
<div id="two"></div>

我尝试使用outerHTML,但它返回了我的信息

代码语言:javascript
复制
<div id="two">
    <div id="three">
        <div id="four">
        <div>
    </div>
</div>

如果我尝试删除innerHTML,它会影响DOM

编辑我尝试了这个$('#two').clone().html('')

它返回给我结果,但是它是正确的吗?

EN

回答 4

Stack Overflow用户

发布于 2014-04-22 22:20:55

代码语言:javascript
复制
    function outerHTML(id){
       var clone = document.getElementById(id).cloneNode();
       clone.innerHTML = "";
       return clone.outerHTML;
    }

    //usage
    outerHTML("one");

JS小提琴: http://jsfiddle.net/6V34p/1

票数 1
EN

Stack Overflow用户

发布于 2014-04-22 22:10:22

我不知道这是不是你想要的,但你有没有尝试过这样的东西。

代码语言:javascript
复制
<div class="divName">
    <div id="123">
       <p>HelloWorld</p>
    </div>
    <div id="456">
       <p>Not Here</p>
   </div>
</div>


var alert = $('#123').clone().wrap('<div></div>').parent().html();
alert(alert);
票数 0
EN

Stack Overflow用户

发布于 2014-04-22 22:13:39

取消outerHTML将始终显示标记及其所有子元素。

代码语言:javascript
复制
<div id="two">
    <div id="three">
        <div id="four">
        <div>
    </div>
</div>

最好的方法是首先使用outerHTML,然后使用jquery隐藏子元素。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23221901

复制
相关文章

相似问题

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