a="12345"
a[2]=3
a[2]='9'
console.log(a) //=> "12345"
到底是怎么回事??这个怪癖给我带来了 1 小时痛苦的调试。如何以明智的方式避免这种情况?
a="12345"
a[2]=3
a[2]='9'
console.log(a) //=> "12345"
到底是怎么回事??这个怪癖给我带来了 1 小时痛苦的调试。如何以明智的方式避免这种情况?
您不能使用方括号来重写字符串的单个字符;只有“getter”(即读取)访问可用。引用文档(MDN):
对于使用方括号表示法的字符访问,尝试删除这些属性或为这些属性赋值将不会成功。所涉及的属性既不可写也不可配置。
那是问题的“发生了什么”部分。对于“如何替换”部分,有一个有用的片段(取自很久很久以前写的答案):
String.prototype.replaceAt = function(index, char) {
return this.slice(0, index) + char + this.slice(index+char.length);
}
您可以按原样使用(咬紧牙关扩展 JS 本机对象) - 或将此代码作为方法注入某个实用程序对象中(显然它应该重写一点,将源字符串作为其第一个参数并使用它而不是this
)。
根据this question,并非所有浏览器都支持此功能。
如果你的字符串不是太长,你可以像这样相对容易地做到这一点:
var a="12345";
a = a.split("");
a[2]='9';
a = a.join("");
console.log(a);
var letters = a.split('');
letters[2] = 3;
letters[2] = 9;
console.log(letters.join(''));
干杯