gpt4 book ai didi

javascript - 如何使用 ReactTestUtils 设置 HTML5 文件类型输入

转载 作者:行者123 更新时间:2023-11-28 01:14:34 26 4
gpt4 key购买 nike

我在 React 表单中有一个 HTML5 文件类型输入,类似于以下内容

<input type='file' ref='fileInput' onChange={this.onChange} multiple/>

文件上传后,this.onChange 访问所选文件,验证它们并转换表单。

我试图弄清楚如何使用 ReactTestUtils.Simulate 测试此功能,但无法弄清楚如何设置应发送到 event.currentTarget.files 中的 onChange 回调的文件。

任何人都可以帮助指导我如何有效地模拟/测试这个正确的方向吗?

最佳答案

发现在调用 TestUtils.Simulate.change 之前,需要在对象上显式设置文件。类似下面的东西应该可以工作。

它是从 Coffeescript 改编而来的 ES6,所以我不确定它的语法是否完全正确。

// Needs to be an integer keyed object instead of an array to mock a file set
const files = {
0: {name: 'test.jpeg'},
1: {name: 'test.mp4'}
};

const fileInput = TestUtils.findRenderedDOMComponentWithTag(<testView>, 'input');
fileInput.files = files;
TestUtils.Simulate.change(fileInput)

关于javascript - 如何使用 ReactTestUtils 设置 HTML5 文件类型输入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36227567/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com