\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%
=~_|]/i
这段正则的功能是匹配URL
这里的\b是为了什么
-a a前面的- 是什么
-a-z0-9+ 后面的一堆&@#\/%?=~_|!:,.; 这些是什么啊。。。。如果是符号匹配的话,不需要加\吗?
* 后的[ ] 又是为了什么,不是已经有*了吗?
最后的 [ ] 后面的 /i 又是什么?
\b:匹配单词边界,即URL前面是个空格
/i : 忽略大小写
-a-z0-9+&@#\/%?=~_|!:,.; : 匹配 “-”,a-z,0-9,“+”,“&”,“@”,“#”,“/”,“%”,“?”,“=”,“~”,“_”,“|”,“!”,“:”,“,”,“.”,“;”
匹配单词。
-a,就是除了字母还可以匹配-号。然后还有其它特殊符号。[]中是字符组。里面都是字符,不需要转义
\b 被称作单词边界,他会匹配一个单词的开始或者结束,产生一个长度为0的匹配,举例:若想匹配my cat is brown的cat,但是不能匹配category或者是bobcat
,就可以用\bcat\b