js利用Regex檢驗輸入內容是否為網址,jsRegex

來源:互聯網
上載者:User

js利用Regex檢驗輸入內容是否為網址,jsRegex

js正則檢驗輸入的是否為網址功能在網頁中也是很常見的,友情連結部分、表單填寫個人首頁的時候,使用JavaScript取驗證是否為網址。 

這個檢驗不好寫,最好還是使用Regex去認證。 

規定,輸入的東西只能是http://與https://開頭,而且必須是網址。 

有人說,為何像www.1.com這樣的網頁不行呢?

這是以免你拿使用者輸入的東西構造超級連結的時候,a標籤中的href屬性如果遇不到http://或者https://的東西,那麼就會認為是根目錄,會在你的網站的網址後面接著寫入這個地址再跳轉,這個大家應該知道。比如<a href="www.1.com">xxx</a>,我的網址是http://localhost,那麼點擊這個顯示為xxx的a標籤之後,則只是跳到http://localhost/www.1.com這個位置,當然不對了。 

比如如下的文字框,如何利用Regex做到要求使用者輸入的必須是http://與https://開頭的網址呢? 

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>網址必須以http://或者https://開頭,且必須是個網址^_^!<br /><input type="text" id="url" /><button onclick="CheckUrl()">確定</button></body></html>

 2、其次是指令碼,其實也不用說了,關鍵是那條Regex:

 <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("這網址不是以http://https://開頭,或者不是網址!"); } 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,因此Regex必須寫在兩個斜杠之中,/.../,然後Regex裡面的斜杠/必須寫成\/
 2、^表示必須以……開頭,[]表示一個檢驗單位,也就是某個字元可以容納的東西,比如^([hH][tT]{2}[pP]:\/\/|[hH][tT]{2}[pP][sS]:\/\/),就是要求以http://或者https://開頭的意思。|是或者,第一個字元是h或者H,第二、三個字元是[tT],{2}是包括這個字元與其後面的1個字元都必須為[tT]的意思,之後以此類推
 3、([A-Za-z0-9-~]+)表示,包括這個字元及其隨後的字元都必須大寫字母、小寫字母、數字、減號-或者是~
 字元+的意思是:匹配+號前面的字元1次或n次,例如:/a+/匹配"candy"中的'a'和"caaaaaaandy"中的所有'a'.
 4、因此(([A-Za-z0-9-~]+)\.)+則表示XXX.這個以點結尾的東西,必須在([A-Za-z0-9-~\/])+$這個字元前面出現至少1次
 5、$表示必須以大寫字母、小寫字母、數字、減號-、~、/結尾

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.