欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

过滤有关问题,继续

更新时间: 2014-01-05 00:57:03 责任编辑: Author_N1

 

过滤问题,继续
在之前发布的一个贴子中。

有如下需求

过滤连续6位以上的数字,并且不在某个白名单中,都需要把数字过滤成红色的****

如:

1348769887

8769887

134988727764

白名单中值为: 8769887

如何用正则,弄成:

134*******

*******

134988727764


谢谢。


得到版主的回复:


<%
s="1348769887<br/>8769887<br/>134988727764"
s=RP(s)
 
response.Write s
%>
<script runat="server" language="jscript">
    function RP(v) {
        var whiterx = /(8769887|8769886)/;//修改你的这个正则如果还有其他白名单
        return v.replace(/(\d{3})(\d{3,})/g, function ($0, $1, $2) {
            if (whiterx.test($0)) return $0;//包含白名单中不替换
            return $1 + '<font color="red">' + $2.replace(/\d/g, '*') + '</font>';
        });
    }
</script>


但如果,变量v的值,为富文本框传来带有html标签的话,就过滤不了,再继续请教??
--参考方法--
并且不在某个白名单中,都需要把数字过滤成红色的****
白名单中值为: 8769887
 
8769887  不是在白名单中? 你下面例子怎么输出 "*******"
看着迷糊

--参考方法--
过滤两次,第一次先将提交过来的所有内容使用电话号码的正则匹配后存入临时表中。
第二次循环查询你的这个临时表,将每条数据按你需求处理后显示出来即可。
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 00:57:03
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/1755/
本文WWW.DOC100.NET DOC100.NET版权所有。