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