瀟湘沐
2023-03-18 16:16:45
我想像這樣創(chuàng)建一個(gè)代理。正如文檔似乎暗示的那樣,我使用了Reflect.set。function createStore<T>(reducer: Reducer<T>, initialState: T) { const store = new Proxy(initialState, { set(target, key, value) { console.log('Trap has been activated'); return Reflect.set(target, key, value); } });}現(xiàn)在當(dāng)我設(shè)置一個(gè)字段時(shí),它確實(shí)有效地觸發(fā)了這個(gè)陷阱。但是,我想在設(shè)置值后觸發(fā)此陷阱。我嘗試了這個(gè),希望Reflect.set返回我的下一個(gè)狀態(tài):const nextState = Reflect.set(target, key, value);// my code herereturn nextState;相反,它返回一個(gè)布爾值。有沒有辦法在返回值之前獲取代理的“下一個(gè)值”?
1 回答

隔江千里
TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超10個(gè)贊
文檔澄清了Reflect.set
一些事情:
返回值
一個(gè)布爾值,指示設(shè)置屬性是否成功。
如果你想得到設(shè)置后的值,你可以使用Reflect.get(target, key)
或直接轉(zhuǎn)到目標(biāo)(target[key]
):
function createStore<T>(reducer: Reducer<T>, initialState: T) {
? const store = new Proxy(initialState, {
? ? set(target, key, value) {
? ? ? console.log('Trap has been activated');
? ? ? const retVal = Reflect.set(target, key, value);
? ? ? console.log(`New value: ${Reflect.get(target, key)}`);
? ? ? return retVal;
? ? }
? });
}
添加回答
舉報(bào)
0/150
提交
取消