分享
 
 
 

用Regular Expression来改变HTML代码

王朝html/css/js·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

我最近在为一个客户开发在线论坛程序,我想把用户发言中的url或e-mail地址用超链接显示出来. 用JavaScript的regular expressions是最容易实现的.

用户在表单里的多行文本框中输入他们的发言内容,然后把消息送到论坛的用户发言区中,然而,在把消息在论坛里显示出来之前,我要调用一个函数来处理消息,对url动些手脚.

我不想在这里讨论如何从数据库里取得一条记录了,这个站点已经说得很透彻了. 我们假设用户的消息文本存放在数据库中,并被赋予了一个叫s_message的变量.

<%

'...start the page and spit out html to the browser

'call the function to convert the message

Response.Write to_html(s_message)

%>

函数如下:

<%

Function to_html(s_string)

to_html = Replace(s_string, """", """)

to_html = Replace(to_html, "<", "<")

to_html = Replace(to_html, ">", ">")

to_html = Replace(to_html, vbcrlf, "

")

to_html = Replace(to_html, "/<", "<")

to_html = Replace(to_html, "/>", ">")

to_html = edit_hrefs(to_html)

End Function

%>

<script language="javascript1.2" runat=server>

function edit_hrefs(s_html){

// use regular expressions to look for

// e_mail addresses and urls

s_str = new String(s_html);

s_str = s_str.replace(/\bhttp\:\/\/www(\.[\w+\.\:\/\_]+)/gi,

"http\:\/\/?¤?$1");

s_str = s_str.replace(/\b(http\:\/\/\w+\.[\w+\.\:\/\_]+)/gi,

"<a href=\"$1\">$1<\/a>" target=_blank);

s_str = s_str.replace(/\b(www\.[\w+\.\:\/\_]+)/gi,

"<a href=\"http://$1\">$1</a>" target=_blank);

s_str = s_str.replace(/\bhttp\:\/\/?¤?(\.[\w+\.\:\/\_]+)/gi,

"<a href=\"http\:\/\/www$1\">http\:\/\/www$1</a>" target=_blank);

s_str = s_str.replace(/\b(\w+@[\w+\.?]*)/gi,

"<a href=\"mailto\:$1\">$1</a>" target=_blank);

return s_str;

}

</script>

上面的代码做了这些事儿:

1. 把引号转换成"这样的html元素. 这不是必需的,但最好这么做.

2. 把小于号转换成html元素<. 这样的话,如果有人在发的消息里用到了小于

号,html会正确输出. 另外,也防止某些人耍小花招,比如用<b>bold</b>来特定的字以粗体显示.

3. 把大于号转换成>. 原因同上.

4. 把回车换行转换成html换行标签"

"

5. 这就是我们要动的手脚. 它允许人们在代码里放入简单的html并逃脱代码的转换. 然而,他们得用"/"来避开对"<>"的代码检查. 我想总会有人找出绕过代码转换的办法的,如果他们办到了,用"牛"来形容他们的水平是再恰当不过的了.

6. 最后,调用JavaScript的edit_hrefs的函数.

现在,让我们来看看每行的JavaScript的函数做了些甚麽:

1. 为传递函数的参数创建一个字符串对象.

2. 把所有的http://www.[something]找出来,转换成http:////?¤?.

[something]. 这是一个临时性的措施,处理所有的www.[something]. 因此

http://www.pinarello.com/被替换成http://?¤?.pinarello.com/.

3. 转换其余的http://[something],有些网址是不以www开头的. 比如

http://uk.imdb.com/将被转换为<a

href="http://uk.imdb.com/">http://uk.imdb.com/</a>

4. 寻找所有的www.[something],把它们转换成html. 比如www.principia.dk将被转换成<a href="http://www.principia.dk">www.principia.dk</a>

5. 把第二部中所有的http://?¤?.[something]/给改回来. 第二步中的http://?

¤?.pinarello.com/将被转换为http://www.pinarello.com/.

6. 最后,找出e-mail地址将其转换为<a href="mailto:[e-mail address]">[e-

mail address]</a>. 我这里用来查找e-mail地址的Regular expression不同于

Ian Stalling的, 但我还没有发现有甚麽e-mail地址用这种办法不能处理的. 然而,它还没有被彻底的测试过. 无论何时,只要你发现存在任何问题,最好马上就Ian's的代码把我写的这些代码给换掉.

你可以把这个函数用于任何用途. 或许你能增强它的功能,或是删去多余的东西,抑或是增加新的函数. 如果你这么做了,你将乐在其中!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有