本文给大家讲解的是使用javascript实现去除多余的TABLE的样式,主要通过结合正则表达式来实现,非常的简单实用,有需要的小伙伴可以参考下。
项目中遇到这样的需求,一大段文章正文的html代码在手机中显示不全,原因是由于其它有table,而table表格中的tr/td都携带了从word中粘贴过来的样式,需要将这一大段的字符串中的table、tr、td中携带的样式清除掉,同时还不能破坏table结构,即要保留tr中的rowspan和td中的colspan属性。
html部分代码如下:
文字中华人民共和国文字中华人民共和国文字中华人民共和国
项目 | 金额 | 经办人 | 是否有发票 |
合计 |
|
文字中华人民共和国文字中华人民共和国文字中华人民共和国。
JS脚本如下:
/* *格式化内容,str即是html格式的字符串 */ function formatContent(str){ str=str.replace(/]*>/ig,""); str=str.replace(/
]*>)/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 ' | '; } }); return str; } |
"); str=str.replace(/<td[^]*>/ig, " | "); str=str.replace(/ | \s*? /ig, " | "); str=str.replace(/\s*?/ig, " | "); str=str.replace(/<td[^]*>\s*?"); str=str.replace(/ | \s*? /ig, " | "); str=str.replace(/\s*?/ig, " | ");
---|