js利用正則表達式檢驗輸入內(nèi)容是否為網(wǎng)址
js正則檢驗輸入的是否為網(wǎng)址功能在網(wǎng)頁中也是很常見的,友情鏈接部分、表單填寫個人主頁的時候,使用JavaScript取驗證是否為網(wǎng)址。
這個檢驗不好寫,最好還是使用正則表達式去認證。
規(guī)定,輸入的東西只能是http://與https://開頭,而且必須是網(wǎng)址。
有人說,為何像www.1.com這樣的網(wǎng)頁不行呢?
這是以免你拿用戶輸入的東西構(gòu)造超級鏈接的時候,a標簽中的href屬性如果遇不到http://或者https://的東西,那么就會認為是根目錄,會在你的網(wǎng)站的網(wǎng)址后面接著寫入這個地址再跳轉(zhuǎn),這個大家應該知道。比如<a href="www.1.com">xxx</a>,我的網(wǎng)址是http://localhost,那么點擊這個顯示為xxx的a標簽之后,則只是跳到http://localhost/www.1.com這個位置,當然不對了。
比如如下的文本框,如何利用正則表達式做到要求用戶輸入的必須是http://與https://開頭的網(wǎng)址呢?

1、首先是一個簡單的布局,這個不用說了:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>無標題文檔</title> </head> <body> 網(wǎng)址必須以http://或者https://開頭,且必須是個網(wǎng)址^_^!<br /> <input type="text" id="url" /> <button onclick="CheckUrl()">確定</button> </body> </html>
2、其次是腳本,其實也不用說了,關(guān)鍵是那條正則表達式:
<script>
function CheckUrl(){
var url=document.getElementById("url").value;
var reg=/^([hH][tT]{2}[pP]:\/\/|[hH][tT]{2}[pP][sS]:\/\/)(([A-Za-z0-9-~]+)\.)+([A-Za-z0-9-~\/])+$/;
if(!reg.test(url)){
alert("這網(wǎng)址不是以http://https://開頭,或者不是網(wǎng)址!");
}
else{
alert("輸入成功");
}
}
</script>
在: var reg=/^([hH][tT]{2}[pP]:\/\/|[hH][tT]{2}[pP][sS]:\/\/)(([A-Za-z0-9-~]+)\.)+([A-Za-z0-9-~\/])+$/;之中,
1、Javascript之中,由于所有變量都是var,因此正則表達式必須寫在兩個斜杠之中,/.../,然后正則表達式里面的斜杠/必須寫成\/
2、^表示必須以……開頭,[]表示一個檢驗單位,也就是某個字符可以容納的東西,比如^([hH][tT]{2}[pP]:\/\/|[hH][tT]{2}[pP][sS]:\/\/),就是要求以http://或者https://開頭的意思。|是或者,第一個字符是h或者H,第二、三個字符是[tT],{2}是包括這個字符與其后面的1個字符都必須為[tT]的意思,之后以此類推
3、([A-Za-z0-9-~]+)表示,包括這個字符及其隨后的字符都必須大寫字母、小寫字母、數(shù)字、減號-或者是~
字符+的意思是:匹配+號前面的字符1次或n次,例如:/a+/匹配"candy"中的'a'和"caaaaaaandy"中的所有'a'.
4、因此(([A-Za-z0-9-~]+)\.)+則表示XXX.這個以點結(jié)尾的東西,必須在([A-Za-z0-9-~\/])+$這個字符前面出現(xiàn)至少1次
5、$表示必須以大寫字母、小寫字母、數(shù)字、減號-、~、/結(jié)尾
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序?qū)崿F(xiàn)音頻文件播放進度的實例代碼
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)音頻文件播放進度的實例代碼,代碼包括對進度條的實現(xiàn)及進度條的滑動,對大家的工作或?qū)W習具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03
G6?TreeGraph樹圖節(jié)點懶加載使用場景示例
這篇文章主要為大家介紹了G6?TreeGraph樹圖節(jié)點懶加載使用場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10
JavaScript設計模式--簡單工廠模式實例分析【XHR工廠案例】
這篇文章主要介紹了JavaScript設計模式--簡單工廠模式,結(jié)合實例形式分析了JavaScript設計模式中簡單工廠模式原理與XHR工廠應用案例,需要的朋友可以參考下2020-05-05
js將table的每個td的內(nèi)容自動賦值給其title屬性的方法
下面小編就為大家?guī)硪黄猨s將table的每個td的內(nèi)容自動賦值給其title屬性的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10

