已经在sublime上写出来了
因为每次调用了exec方法
只会返回该RegExp对象的当次的数据
我的例子中匹配了4次 看看我的解释是否合理
例如第二种情况 我在While语句的条件中调用了一次(1)
然后再在While语句中调用了第二次(2)赋给ret
于是ret只储存第二次(偶数次)的内容
我打印出来就只有偶数次了
第三种情况类似
只有老师的那种情况 只在条件语句中调用一次 然后赋给ret
于是ret就不会因为lastIndex的原因 跳过任何一次遍历 所有4次都成功
就像sublime 下面执行的一样
正则表达式exec()函数:
exec() 方法用于检索字符串中的正则表达式的匹配。
返回值是一个数组,但是此数组的内容和正则对象是否是全局匹配有着很大关系:
1.没有g修饰符:
在非全局匹配模式下,此函数的作用和match()函数是一样的,只能够在字符串中匹配一次,如果没有找到匹配的字符串,那么返回null,否则将返回一个数组,数组的第0个元素存储的是匹配字符串,第1个元素存放的是第一个引用型分组(子表达式)匹配的字符串,第2个元素存放的是第二个引用型分组(子表达式)匹配的字符串,依次类推。同时此数组还包括两个对象属性,index属性声明的是匹配字符串的起始字符在要匹配的完整字符串中的位置,input属性声明的是对要匹配的完整字符串的引用。
特别说明:
在非全局匹配模式下,IE浏览器还会具有lastIndex属性,不过这时是只读的。
2.具有g修饰符:
在全局匹配模式下,此函数返回值同样是一个数组,并且也只能够在字符串中匹配一次。不过此时,此函数一般会和lastIndex属性匹配使用,此函数会在lastIndex属性指定的字符处开始检索字符串,当exec()找到与表达式相匹配的字符串时,在匹配后,它将lastIndex
属性设置为匹配字符串的最后一个字符的下一个位置。可以通过反复调用exec()函数遍历字符串中的所有匹配,当exec()函数再也找不到匹配的文本时,它将返回null,并把lastIndex
属性重置为0。
数组的内容结构和没有g修饰符时完全相同。
特别说明:
如果在一个字符串中完成了一次模式匹配之后要开始检索新的字符串,就必须手动地把lastIndex属性重置为0。
复习一下while。。。。第一次条件满足时候赋值一次,等语句块执行完,才执行的while内的条件,即第二次赋值,这时候第一次已经输出了,不存在两次什么的。。。。