- 出現(xiàn)這種錯(cuò)誤一般是因?yàn)椴粩喈a(chǎn)生大量數(shù)據(jù)占滿堆棧內(nèi)存
- 我今天的案例在于Class中使用
getter
和setter
方法時(shí)床蜘,出現(xiàn)如上報(bào)錯(cuò)
后來了解到原因:
class Example{
constructor(a, b) {
this.a = a; // 實(shí)例化時(shí)調(diào)用 set 方法
this.b = b;
}
get a(){
console.log('getter');
return this.a;
}
set a(a){
console.log('setter');
this.a = a; // 自身遞歸調(diào)用
}
}
let exam = new Example(1,2); // 不斷輸出 setter ,最終導(dǎo)致 RangeError
class Example1{
constructor(a, b) {
this.a = a;
this.b = b;
}
get a(){
console.log('getter');
return this._a;
}
set a(a){
console.log('setter');
this._a = a;
}
}
let exam1 = new Example1(1,2); // 只輸出 setter , 不會(huì)調(diào)用 getter 方法
console.log(exam._a); // 1, 可以直接訪問
之后封鎖屬性使之不可修改的方法是Object.freeze()