javascript - 去除标签间的空白字符
黄舟
黄舟 2017-04-10 17:55:29
[JavaScript讨论组]

去除所有子元素的空白标签,以下代码为例

1

2

3

4

5

6

7

8

9

10

11

12

<code><p>

    <ul>

        <li>js</li><!--js-->

        <li>html</li><!--html-->

        <li>css</li><!--css-->

    </ul>

    <ul>

        <li>js</li><!--js-->

        <li>html</li><!--html-->

        <li>css</li><!--css-->

    </ul>

</p></code>

找到一种方法

1

2

3

4

5

6

7

8

<code>  function cleanWhitespace(p) {

    for(var i=0;i<p.childNodes.length;i++){ 

      var node = p.childNodes[i]; 

      if(node.nodeType == 3 && !/\S/.test(node.nodeValue)){ 

        node.parentNode.removeChild(node);

      

    

  }</code>

但是,childNodes是直接元素,那么去掉ul里面的元素怎么做,考虑更深层嵌套的话。有没有获取所有节点的方法(children(),getElementByTagName(*)都是不能获取到空白的文本节点)??或是有更好的方法介绍,大神们~~

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(1)
伊谢尔伦

不是很理解你的题意,你是指深层嵌套的处理么?那递归处理可以吧~

1

2

3

4

5

6

7

8

9

10

11

<code>function cleanWhitespace(p) {

    for(var i=0;i<p.childNodes.length;i++){ 

      var node = p.childNodes[i]; 

      if(node.nodeType == 3 && !/\S/.test(node.nodeValue)){ 

        node.parentNode.removeChild(node);

        i--;//直接删除节点childNodes有变动

      }else if(node.nodeType == 1){//子元素还是元素就递归清理子元素

          cleanWhitespace(node);

      }

    

  }</code>

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号