Javascript 你不知道的事
相应的第一次替换中,arguments的内容为:
Arguments[5]exec方法的返回结果是一个JS数组,并附带两个额外的属性index和input。与上面replace对应的exec方法第一次执行的返回结果对照如下:
- 0"30n"
- 1"30"
- 2"n"
- 34
- 4"fon230nva09dnfadsf"
Array[3]string的match方法根据g标识来决定如何进行匹配。如果没有g标识,那么调用string.match(regexp)的结果与第一次调用regexp.exec(string)的结果相同。如果regexp带有g标识,那么它返回一个包含所有匹配的字符串的数组。
- 0: "30n"
- 1: "30"
- 2: "n"
- index: 4
- input: "fon230nva09dnfadsf"
- length: 3
输出结果:Array[3]输出结果:Array[2]
- 0: "30n"
- 1: "30"
- 2: "n"
- index: 4
- input: "fon230nva09dnfadsf"
- length: 3
string的split(separator,limit)方法把string分割成片段,来创建一个字符串数组。可选参数limit可以限制被分割的片段数量。separator参数可以是一个字符串或一个正则表达式,并且来自分组捕获的文本将会被包含在被分割后的数组中。下面给出一个综合的例子:
- 0: "30n"
- 1: "09d"
- length: 2
var x=10;var foo = { x:20, bar:function(){ var x = 30; return this.x; }}var a = (foo.bar)();//括号不影响表达式的值,相当于直接调用foo.bar()var b = (foo.bar=foo.bar)();//括号表达式返回赋值操作的结果,也就是foo的成员bar函数;而调用的时候已经回到了全局作用域。var c = (foo.bar,foo.bar)();//与上式相同,都是返回表达式的结果,也就是后面的bar函数,同样相当于在全局作用域调用bar函数。因此a、b、c的值分别为20,10,10。