$scope.regex = '^((http|https|ftp):\/\/)?([a-z]+\.)?[a-z0-9-]+(\.[a-z]{1,4}){1,2}(/.*\?.*)?$';
This is the regular expression i'm using to validate url, and its working fine. I have checked it on AngularJS website.

<div class="field_input">
<div style="width: 100%;">
<input type="text" name="website" ng-model="custom.websites" placeholder="www.daiict.ac.in" ng-minlength=3 ng-pattern="regex" required/>
</div>
</div>
<div class="valid-chk" ng-show="requestForm1.website.$dirty" style="margin-top: 5px;">
<i style="font-size: 1.15em;padding:0px;" ng-class="{'false':'icon-close', 'true': 'icon-correct'}[requestForm1.website.$valid]" class="icon-correct"></i>
</div>
&#13;
这是html片段,我试图验证输入字段。 但这不起作用。此外,当我使用ng-pattern时,输入字段上的所有其他验证(除了必需)也不起作用。不知道为什么......
答案 0 :(得分:8)
您的ng-pattern="regex"
包含字符串regex
作为其值。要引用实变量$scope.regex
,您需要使用模板语法:
ng-pattern="{{regex}}"
此外,由于模式是使用字符串定义的,因此您需要双重转义反斜杠(请参阅a similar example code at the ngPattern reference page):
$scope.regex = '^((https?|ftp)://)?([A-Za-z]+\\.)?[A-Za-z0-9-]+(\\.[a-zA-Z]{1,4}){1,2}(/.*\\?.*)?$';
或者只是将它们放入一个字符类中以避免任何歧义:
$scope.regex = '^((https?|ftp)://)?([a-z]+[.])?[a-z0-9-]+([.][a-z]{1,4}){1,2}(/.*[?].*)?$';
或者甚至传递RegExp
对象,因为你可以使用不区分大小写的标志:
$scope.regex = "/^((https?|ftp):\\/\\/)?([a-z]+[.])?[a-z0-9-]+([.][a-z]{1,4}){1,2}(\\/.*[?].*)?$/i";
或者,可以使用RegExp构造函数定义与上面相同的表达式:
$scope.regex = RegExp('^((https?|ftp)://)?([a-z]+[.])?[a-z0-9-]+([.][a-z]{1,4}){1,2}(/.*[?].*)?$', 'i');
我还建议将http|https
缩短为https?
。
答案 1 :(得分:1)
可以尝试使用new RegExp
new RegExp(pattern, option)
我使用i
作为选项来忽略大小写
$scope.regex = $scope.regex = new RegExp('^((https?|ftp)://)?([a-z]+[.])?[a-z0-9-]+([.][a-z]{1,4}){1,2}(/.*[?].*)?$', 'i');