以下是我用来验证网站 URL 的 URL 表达式(正则表达式):
/(https?:\/\/)(www)?[A-Za-z0-9.\-@_~]+\.[A-Za-z]{2,}(:[0-9]{2,5})?(\/[A-Za-z0-9\/_\-.~?&=]*)*/
我的 Angular JS 代码实现如下:
<md-input-container class="md-block" style="margin-top:20px;">
<label>Website</label>
<input ng-model="schoolDetails.website" name="website" ng-change="editField()" type="url" ng-pattern="/(https?:\/\/)(www)?[A-Za-z0-9.\-@_~]+\.[A-Za-z]{2,}(:[0-9]{2,5})?(\/[A-Za-z0-9\/_\-.~?&=]*)*/">
<div ng-messages="schoolDetailsForm.website.$error">
<div ng-message="pattern">Please enter a valid website</div>
</div>
</md-input-container>
假设我提供了有效的 URL http://www.bharatividyapeeth.edu
,它可以正常工作。如果我提供了无效的 URL,http://www.
则会出现错误消息,但是当我输入无效的 URL 时,http://www.bharatividyapeeth
它不会显示错误消息并接受它作为有效的 URL。
有人可以更正我的代码以正确验证网站 URL 吗?
谢谢。