首页 > 解决方案 > 如何模拟 React.MouseEvent<{}, MouseEvent> onClick 事件?

问题描述

我正在使用 Jest 测试一个用 TypeScript 编写的 React 组件。我不能使用.simulate(),因为不赞成直接调用组件的onClick()函数道具。这是我的测试代码:

// Get the onClick function
const buttonOnClick = wrapper.find('#diffpicker-button').first().props().onClick;

// Make sure the function is not undefined
if (!buttonOnClick) return;

// Mock event
const clickEvent = new MouseEvent('click');
Object.assign(clickEvent, { preventDefault: jest.fn() });

// Call the onClick function
buttonOnClick(clickEvent);

但是,当我这样做时,我收到错误:Argument of type 'MouseEvent' is not assignable to parameter of type 'MouseEvent<{}, MouseEvent>'.我的问题是,如何模拟 MouseEvent<{}、MouseEvent> 类型的事件?

标签: javascriptreactjstypescriptjestjsenzyme

解决方案


推荐阅读