一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - 正則表達(dá)式 - js利用正則表達(dá)式檢驗(yàn)輸入內(nèi)容是否為網(wǎng)址

js利用正則表達(dá)式檢驗(yàn)輸入內(nèi)容是否為網(wǎng)址

2021-11-30 12:04yongh701 正則表達(dá)式

這篇文章主要為大家詳細(xì)介紹了js利用正則表達(dá)式檢驗(yàn)輸入內(nèi)容是否為網(wǎng)址的相關(guān)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

js正則檢驗(yàn)輸入的是否為網(wǎng)址功能在網(wǎng)頁(yè)中也是很常見(jiàn)的,友情鏈接部分、表單填寫(xiě)個(gè)人主頁(yè)的時(shí)候,使用JavaScript取驗(yàn)證是否為網(wǎng)址。 

這個(gè)檢驗(yàn)不好寫(xiě),最好還是使用正則表達(dá)式去認(rèn)證。 

規(guī)定,輸入的東西只能是http://與https://開(kāi)頭,而且必須是網(wǎng)址。 

有人說(shuō),為何像www.1.com這樣的網(wǎng)頁(yè)不行呢?

這是以免你拿用戶(hù)輸入的東西構(gòu)造超級(jí)鏈接的時(shí)候,a標(biāo)簽中的href屬性如果遇不到http://或者h(yuǎn)ttps://的東西,那么就會(huì)認(rèn)為是根目錄,會(huì)在你的網(wǎng)站的網(wǎng)址后面接著寫(xiě)入這個(gè)地址再跳轉(zhuǎn),這個(gè)大家應(yīng)該知道。比如<a href="www.1.com">xxx</a>,我的網(wǎng)址是http://localhost,那么點(diǎn)擊這個(gè)顯示為xxx的a標(biāo)簽之后,則只是跳到http://localhost/www.1.com這個(gè)位置,當(dāng)然不對(duì)了。 

比如如下的文本框,如何利用正則表達(dá)式做到要求用戶(hù)輸入的必須是http://與https://開(kāi)頭的網(wǎng)址呢? 

js利用正則表達(dá)式檢驗(yàn)輸入內(nèi)容是否為網(wǎng)址

1、首先是一個(gè)簡(jiǎn)單的布局,這個(gè)不用說(shuō)了:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
<!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>無(wú)標(biāo)題文檔</title>
</head>
 
<body>
網(wǎng)址必須以http://或者h(yuǎn)ttps://開(kāi)頭,且必須是個(gè)網(wǎng)址^_^!<br />
<input type="text" id="url" />
<button onclick="CheckUrl()">確定</button>
</body>
</html>

 2、其次是腳本,其實(shí)也不用說(shuō)了,關(guān)鍵是那條正則表達(dá)式:

?
1
2
3
4
5
6
7
8
9
10
11
12
<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://開(kāi)頭,或者不是網(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,因此正則表達(dá)式必須寫(xiě)在兩個(gè)斜杠之中,/.../,然后正則表達(dá)式里面的斜杠/必須寫(xiě)成\/
 2、^表示必須以……開(kāi)頭,[]表示一個(gè)檢驗(yàn)單位,也就是某個(gè)字符可以容納的東西,比如^([hH][tT]{2}[pP]:\/\/|[hH][tT]{2}[pP][sS]:\/\/),就是要求以http://或者h(yuǎn)ttps://開(kāi)頭的意思。|是或者,第一個(gè)字符是h或者H,第二、三個(gè)字符是[tT],{2}是包括這個(gè)字符與其后面的1個(gè)字符都必須為[tT]的意思,之后以此類(lèi)推
 3、([A-Za-z0-9-~]+)表示,包括這個(gè)字符及其隨后的字符都必須大寫(xiě)字母、小寫(xiě)字母、數(shù)字、減號(hào)-或者是~
 字符+的意思是:匹配+號(hào)前面的字符1次或n次,例如:/a+/匹配"candy"中的'a'和"caaaaaaandy"中的所有'a'.
 4、因此(([A-Za-z0-9-~]+)\.)+則表示XXX.這個(gè)以點(diǎn)結(jié)尾的東西,必須在([A-Za-z0-9-~\/])+$這個(gè)字符前面出現(xiàn)至少1次
 5、$表示必須以大寫(xiě)字母、小寫(xiě)字母、數(shù)字、減號(hào)-、~、/結(jié)尾

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 香蕉久久一区二区不卡无毒影院 | 欧美添下面视频免费观看 | 白丝尤物的下面被疯狂蹂躏 | 交欧美| 国产精品99在线观看 | 国产一区视频在线免费观看 | 香蕉tv亚洲专区在线观看 | 久久丫线这里只精品 | 91天堂在线 | 女同69式互添在线观看免费 | 99在线免费播放 | 亚洲伦理视频 | 欧美特黄一级大片 | 国产一级特黄aa大片免费 | 国产精品一区二区久久 | 全彩成人18h漫画 | www.色老板| 欧美在线视频一区二区 | 免费视频完整版在线观看网站 | 无码人妻丰满熟妇啪啪网不卡 | 性色欲情网站IWWW九文堂 | 百合女女师生play黄肉黄 | 成人毛片1024你懂的 | 久久视频在线视频观看精品15 | 国产精品香蕉一区二区三区 | 亚洲精品二三区伊人久久 | 情缘1完整版在线观看 | 精品视频在线免费播放 | 69欧美另类xxxxx高清 | 青青草国产免费国产是公开 | 亚洲成年 | 草草免费观看视频在线 | 女人pp被扒开流水了 | 手机看片福利盒子久久 | 手机在线免费观看高清 | 免费网址在线观看入口推荐 | 国产成人8x视频一区二区 | 希岛爱理aⅴ在线中文字幕 午夜综合网 | 亚洲日韩精品欧美一区二区一 | 女女同性做爰xxoo亲吻 | 继攵催眠女乱h调教 |