我试图设置一个regexp,它将检查字符串的开始,如果它包含http://或https://,它应该匹配它。
我该怎么做呢?我正在尝试下面的,但它不起作用:
^[(http)(https)]://
我试图设置一个regexp,它将检查字符串的开始,如果它包含http://或https://,它应该匹配它。
我该怎么做呢?我正在尝试下面的,但它不起作用:
^[(http)(https)]://
当前回答
^作为字符串模式的开始,
? 允许0或1次重复。ie。,年代?S可以存在1次或者根本不需要存在。
/是正则表达式中的一个特殊字符,因此需要用反斜杠\/进行转义
/^https?:\/\//.test('https://www.bbc.co.uk/sport/cricket'); // true
/^https?:\/\//.test('http://www.bbc.co.uk/sport/cricket'); // true
/^https?:\/\//.test('ftp://www.bbc.co.uk/sport/cricket'); // false
其他回答
您使用[]是不正确的——请注意,[]表示字符类,因此只匹配一个字符。表达式[(http)(https)]翻译成“匹配a(,一个h,一个t,一个t,一个p, a),或一个s。”(重复字符将被忽略。)
试试这个:
^https?://
如果你真的想使用交替,请使用以下语法:
^(http|https)://
^https?://
不过,您可能必须转义正斜杠,这取决于上下文。
^https?:\/\/(.*)其中(.*)匹配https://之后的所有内容
这应该可以
^(http|https)://
^作为字符串模式的开始,
? 允许0或1次重复。ie。,年代?S可以存在1次或者根本不需要存在。
/是正则表达式中的一个特殊字符,因此需要用反斜杠\/进行转义
/^https?:\/\//.test('https://www.bbc.co.uk/sport/cricket'); // true
/^https?:\/\//.test('http://www.bbc.co.uk/sport/cricket'); // true
/^https?:\/\//.test('ftp://www.bbc.co.uk/sport/cricket'); // false