javascript自動給文本url地址增加鏈接的方法分享
URL地址自動添加的實現(xiàn)其實就是那么點內容:檢測與替換。
檢測
“檢測”就是檢測文字(字符串)內部是否有符合http地址的內容,顯然,這需要用到正則表達式進行驗證,這個工作前端和后臺都可以做,這里,只講前端的方法,使用JavaScript實現(xiàn)。
驗證HTTP地址的正則表達式如下(可能有疏漏或是不準確之處,歡迎指正):
var reg = /(http://|https://)((w|=|?|.|/|&|-)+)/g;
前一部分匹配http或是https開頭的URL字符串地址,后面一部分匹配一些字符,英文字符、下劃線(_)、點號(.)、問號(?)以及等號(=),連接短線(-)等。
替換 chabaoo.cn
說到JavaScript中的替換功能,首先想到的自然是replace屬性了,replace屬性強大之處在于其支持正則表達式,可以對符合正則的字符串進行替換。例如,我們要替換掉字符串兩端的空格就可以使用類似下面的語句:
var s = " blank ";
s = s.replace(/^s+(.*?)s+$/, "");
alert(s);
就會得到”blank”,兩端的空格被剔除了。同樣的,這里只要將匹配的http地址替換成<a>標簽嵌套的含有href屬性的http地址就可以了
例,這個表達式可以匹配 http,https,ftp,ftps以及IP地址的URL地址。
var URL = /(https?://|ftps?://)?((d{1,3}.d{1,3}.d{1,3}.d{1,3})(:[0-9]+)?|([w]+.)(S+)(w{2,4})(:[0-9]+)?)(/?([w#!:.?+=&%@!-/]+))?/ig;
還算是URL地址匹配計較完善的。利用這個表達式我寫了兩個小函數,將用戶留言的URL地址替換成可點擊的鏈接,沒有什么太難的,就是利用JavaScript 的 replace() 函數來實現(xiàn)替換 URL 為 link:
/**
* JavaScrit 版本
* 將URL地址轉化為完整的A標簽鏈接代碼
*/
var replaceURLToLink = function (text) {
text = text.replace(URL, function (url) {
var urlText = url;
if (!url.match('^https?://')) {
url = 'http://' + url;
}
return '' + urlText + '';
});
return text;
};
相關文章
javascript創(chuàng)建頁面蒙板的一些知識技巧總結
javascript創(chuàng)建頁面蒙板的一些知識技巧總結...2007-08-08javascript游戲開發(fā)之《三國志曹操傳》零部件開發(fā)(四)用地圖塊拼成大地圖
小時候我們玩過拼圖游戲,是用自己的手去拼的。今天我們來研究研究用javascript來拼圖感興趣的朋友可以了解下,希望本文對你有所幫助2013-01-01JavaScript中去掉數組中的重復值的實現(xiàn)方法
百度面試時問的一道題目,蠻常規(guī)的,但是當時自己的回答挺差勁的。現(xiàn)在總結記錄下~2011-08-08JavaScript Perfection kill 測試及答案
近日,在Perfection kill上看到有關javascript quiz。并做了一下,最終錯了2個(#2,#9),但是,這2道題,在Ie和ff下的答案是不一樣的?!2010-03-03Javascript在IE或Firefox下獲取鼠標位置的代碼
由于Firefox和IE等瀏覽器之間對JS解釋的方式不一樣,F(xiàn)irefox下面獲取鼠標位置不能夠直接使用clientX來獲取。網上說的一般都是觸發(fā)mousemove事件才行。我這里有兩段代碼,思路都一樣,就是風格不同。2009-12-12