zoukankan      html  css  js  c++  java
  • javascript格式化table标签内容

    项目中遇到这样的需求,一大段文章正文的html代码在手机中显示不全,原因是由于其它有table,而table表格中的tr/td都携带了从word中粘贴过来的样式,需要将这一大段的字符串中的table、tr、td中携带的样式清除掉,同时还不能破坏table结构,即要保留tr中的rowspan和td中的colspan属性。

    html部分代码如下:

    <class="MsoNormal" align="left" style="text-align:left"><span lang="EN-US">
      <o:p>文字中华人民共和国文字中华人民共和国文字中华人民共和国</o:p>
      </span></p>
    <table>
      <tbody>
        <tr style="height:13.5pt">
          <td width="117" style="88.0pt;border:solid windowtext 1.0pt;padding:0cm 5.4pt 0cm 5.4pt;height:13.5pt"><class="MsoNormal" align="center" style="text-align:center"><span style="font-family:宋体;color:#1F497D">项目<span lang="EN-US">
              <o:p></o:p>
              </span></span></p></td>
          <td width="137" style="103.0pt;border:solid windowtext 1.0pt;border-left:none;padding:0cm 5.4pt 0cm 5.4pt;height:13.5pt"><class="MsoNormal" align="center" style="text-align:center"><span style="font-family:宋体;color:#1F497D">金额<span lang="EN-US">
              <o:p></o:p>
              </span></span></p></td>
          <td width="153" style="115.0pt;border:solid windowtext 1.0pt;border-left:none;padding:0cm 5.4pt 0cm 5.4pt;height:13.5pt"><class="MsoNormal" align="center" style="text-align:center"><span style="font-family:宋体;color:#1F497D">经办人<span lang="EN-US">
              <o:p></o:p>
              </span></span></p></td>
          <td width="135" style="101.0pt;border:solid windowtext 1.0pt;border-left:none;padding:0cm 5.4pt 0cm 5.4pt;height:13.5pt"><class="MsoNormal" align="center" style="text-align:center"><span style="font-family:宋体;color:#1F497D">是否有发票<span lang="EN-US">
              <o:p></o:p>
              </span></span></p></td>
        </tr>
        <tr style="height:13.5pt">
          <td width="117" style="88.0pt;border:solid windowtext 1.0pt;border-top:none;padding:0cm 5.4pt 0cm 5.4pt;height:13.5pt"><class="MsoNormal" align="center" style="text-align:center"><span style="font-family:宋体;color:#1F497D">合计<span lang="EN-US">
              <o:p></o:p>
              </span></span></p></td>
          <td colspan="3" valign="bottom" nowrap="" style="103.0pt;border-top:none;border-left:none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;padding:0cm 5.4pt 0cm 5.4pt;height:13.5pt"><class="MsoNormal" align="center" style="text-align:center"><span lang="EN-US" style="font-size:11.0pt;font-family:宋体;color:black">
              <o:p></o:p>
              </span></p></td>
        </tr>
      </tbody>
    </table>
    <class="MsoNormal"><span style="font-family:宋体;color:#1F497D">文字中华人民共和国文字中华人民共和国文字中华人民共和国。</span><span lang="EN-US" style="color:#1F497D">
      <o:p></o:p>
      </span></p>

    JS脚本如下:

    /*
     *格式化内容,str即是html格式的字符串
     */
    function formatContent(str){
        str=str.replace(/</?(html|head|title|meta|body)[^>]*>/ig,"");
        str=str.replace(/<table[^>]*>/ig,"<table>");
        str=str.replace(/(<tr[^>]*>)/ig, function (a, b) {
            if(a.indexOf('rowspan')>-1){
                a=a.replace(/([a-z]+)="([^"]+)?"/ig,function(c,d,e){
                    return d === 'rowspan' ? (d + '="' + e + '"') : '';
                })
                return a;
            }else{
                return '<tr>';
            }
        });
        str=str.replace(/(<td[^>]*>)/ig, function (a, b) {
            if(a.indexOf('colspan')>-1){
                a=a.replace(/([a-z]+)="([^"]+)?"/ig,function(c,d,e){
                    return d === 'colspan' ? (d + '="' + e + '"') : '';
                })
                return a;
            }else{
                return '<td>';
            }
        });
        return str;
    }
  • 相关阅读:
    JavaScript之正则表达式(2)
    JavaScript之正则表达式(1)
    交换两个变量的值,不借助第三个变量的 三种方法(JS实现)
    网络基础之 OSI七层模型
    jq获取被选中的option的值。jq获取被选中的单选按钮radio的值。
    常见的XSS攻击代码
    php缓存模块apc可能导致php-fpm终止
    Flex布局:实现左右两列自伸缩撑满效果的
    linux系统莫名被黑的诡异经历
    谈谈我对php通信的理解及人生小感
  • 原文地址:https://www.cnblogs.com/dzlishen/p/4641358.html
Copyright © 2011-2022 走看看