6
a="12345"
a[2]=3
a[2]='9'
console.log(a) //=> "12345"

到底是怎么回事??这个怪癖给我带来了 1 小时痛苦的调试。如何以明智的方式避免这种情况?

4

3 回答 3

8

您不能使用方括号来重写字符串的单个字符;只有“getter”(即读取)访问可用。引用文档(MDN):

对于使用方括号表示法的字符访问,尝试删除这些属性或为这些属性赋值将不会成功。所涉及的属性既不可写也不可配置。

那是问题的“发生了什么”部分。对于“如何替换”部分,有一个有用的片段(取自很久很久以前写的答案):

String.prototype.replaceAt = function(index, char) {
    return this.slice(0, index) + char + this.slice(index+char.length);
}

您可以按原样使用(咬紧牙关扩展 JS 本机对象) - 或将此代码作为方法注入某个实用程序对象中(显然它应该重写一点,将源字符串作为其第一个参数并使用它而不是this)。

于 2012-11-14T00:26:37.290 回答
4

根据this question,并非所有浏览器都支持此功能。

如果你的字符串不是太长,你可以像这样相对容易地做到这一点:

var a="12345";
a = a.split("");
a[2]='9';
a = a.join("");
console.log(a);
于 2012-11-14T00:29:58.833 回答
1
var letters = a.split('');
letters[2] = 3;
letters[2] = 9;
console.log(letters.join(''));

http://jsfiddle.net/XWwKz/

干杯

于 2012-11-14T00:29:40.847 回答