React Jest:- node:internal/process/promises:246 triggerUncaughtException(err, true /* fromPromise */);
React Jest:- node:internal/process/promises:246 triggerUncaughtException(err, true /* fromPromise */);
我在反应中有以下代码。
useEffect(() => {
(async () => {
await httpClient
.get(`${config.resourceServerUrl}/inventory/`)
.then((response) => {
setSponsor(response.data.sponsor);
setAddress(response.data.address);
setPhaseOfTrial(response.data.phaseOfTrial);
})
.catch((error) => {
alert(error);
});
})();
}, []);
此代码成功运行。唯一的问题是,它在开玩笑的测试用例中失败了。
describe('ListInventory', () => {
it('should render successfully', () => {
const { baseElement } = render(<ListInventory />);
expect(baseElement).toBeTruthy();
});
});
下面是错误。
node:internal/process/promises:246
triggerUncaughtException(err, true /* fromPromise */);
^
[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "TypeError: Cannot read properties of undefined (reading 'get')".] {
code: 'ERR_UNHANDLED_REJECTION'
}
我已经在使用 catch
块。代码有什么问题?你能帮我做同样的事吗?
尝试使用 try-catch 块处理承诺,如:
useEffect(() => {
(async () => {
try {
let response = await httpClient.get(
`${config.resourceServerUrl}/inventory/`
);
setSponsor(response.data.sponsor);
setAddress(response.data.address);
setPhaseOfTrial(response.data.phaseOfTrial);
} catch(error) {
alert(error);
}
})();
}, []);
或
useEffect(() => {
(async () => {
let response = await httpClient.get(
`${config.resourceServerUrl}/inventory/`
);
setSponsor(response.data.sponsor);
setAddress(response.data.address);
setPhaseOfTrial(response.data.phaseOfTrial);
})().catch(e=>alert(e));
}, []);
我运行遇到了类似的问题。
此问题可能是由于 response.data 旁边的对象之一未定义。
添加条件以检查其存在。
这解决了我的问题
我在反应中有以下代码。
useEffect(() => {
(async () => {
await httpClient
.get(`${config.resourceServerUrl}/inventory/`)
.then((response) => {
setSponsor(response.data.sponsor);
setAddress(response.data.address);
setPhaseOfTrial(response.data.phaseOfTrial);
})
.catch((error) => {
alert(error);
});
})();
}, []);
此代码成功运行。唯一的问题是,它在开玩笑的测试用例中失败了。
describe('ListInventory', () => {
it('should render successfully', () => {
const { baseElement } = render(<ListInventory />);
expect(baseElement).toBeTruthy();
});
});
下面是错误。
node:internal/process/promises:246
triggerUncaughtException(err, true /* fromPromise */);
^
[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "TypeError: Cannot read properties of undefined (reading 'get')".] {
code: 'ERR_UNHANDLED_REJECTION'
}
我已经在使用 catch
块。代码有什么问题?你能帮我做同样的事吗?
尝试使用 try-catch 块处理承诺,如:
useEffect(() => {
(async () => {
try {
let response = await httpClient.get(
`${config.resourceServerUrl}/inventory/`
);
setSponsor(response.data.sponsor);
setAddress(response.data.address);
setPhaseOfTrial(response.data.phaseOfTrial);
} catch(error) {
alert(error);
}
})();
}, []);
或
useEffect(() => {
(async () => {
let response = await httpClient.get(
`${config.resourceServerUrl}/inventory/`
);
setSponsor(response.data.sponsor);
setAddress(response.data.address);
setPhaseOfTrial(response.data.phaseOfTrial);
})().catch(e=>alert(e));
}, []);
我运行遇到了类似的问题。
此问题可能是由于 response.data 旁边的对象之一未定义。 添加条件以检查其存在。
这解决了我的问题