手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >asp.net正则表达式删除指定的HTML标签的代码
asp.net正则表达式删除指定的HTML标签的代码
摘要:如果全盘删除里面的HTML标签,可能会造成阅读上的困难(比如a,img这些标签),最好是删除一部分,保留一部分.正则表达式里,判断包含某些字...

如果全盘删除里面的 HTML 标签,可能会造成阅读上的困难(比如 a, img 这些标签), 最好是删除一部分,保留一部分.

正则表达式里,判断 包含某些字符串 是非常容易理解的,但是如何判断 不包含某些字符串 (是字符串,不是字符,是某些,不是某个) 确实是个费解的事.

复制代码 代码如下:

<(?!((/?s?li)|(/?s?ul)|(/?s?a)|(/?s?img)|(/?s?br)|(/?s?span)|(/?s?b)))[^>]+>

这个正则是判断HTML标签不包含 li / ul / a / img / br / span / b 的,就上面的要求来说,是要 删除 除这里列出的HTML标签,这也是我摸索了很长时间才搞出来的.

(?!exp) 匹配后面跟的不是exp的位置

/?s? 我一开始试着把它写到最前面的 < 后面,但是测试失败了.

下面是一个简单的函数,把要保留的TAG串起来,生成一个正则表达式,然后把不需要的TAG删除...

复制代码 代码如下:

private static string RemoveSpecifyHtml(string ctx) {

string[] holdTags = { "a", "img", "br", "strong", "b", "span" };//要保留的 tag

// <(?!((/?s?li)|(/?s?ul)|(/?s?a)|(/?s?img)|(/?s?br)|(/?s?span)|(/?s?b)))[^>]+>

string regStr = string.Format(@"<(?!((/?s?{0})))[^>]+>", string.Join(@")|(/?s?", holdTags));

Regex reg = new Regex(regStr, RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.IgnoreCase);

return reg.Replace(ctx, "");

}

修正:

上面的正则,如果保留了 li , 实际运行会发现 link 也给保留下来了, 保留 a 会把 addr 也给保留下来, 解决办法就是加 b 断言.

复制代码 代码如下:

<(?!((/?s?lib)|(/?s?ul)|(/?s?ab)|(/?s?imgb)|(/?s?brb)|(/?s?spanb)|(/?s?bb)))[^>]+>

private static string RemoveSpecifyHtml(string ctx) {

string[] holdTags = { "a", "img", "br", "strong", "b", "span", "li" };//保留的 tag

// <(?!((/?s?lib)|(/?s?ulb)|(/?s?ab)|(/?s?imgb)|(/?s?brb)|(/?s?spanb)|(/?s?bb)))[^>]+>

string regStr = string.Format(@"<(?!((/?s?{0})))[^>]+>", string.Join(@"b)|(/?s?", holdTags));

Regex reg = new Regex(regStr, RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.IgnoreCase);

return reg.Replace(ctx, "");

}

【asp.net正则表达式删除指定的HTML标签的代码】相关文章:

asp.net 文件下载实现代码

Asp.net 无限级分类实例代码

asp.net下利用JS实现对后台CS代码的调用方法

asp.net中利用ashx实现图片防盗链代码

asp.net 获取图片高度和宽度实例代码

asp.net(c#)利用构造器链的代码

asp.net下百度的编码和解码

asp.net保存远程图片的代码

asp.net水晶报表参数字段在代码中赋值的方法

记录asp.net网站是什么原因导致停止运行的代码

精品推荐
分类导航