Simulating user input for TDD JavaScript(模拟 TDD JavaScript 的用户输入)
问题描述
I'm finding it increasingly difficult to simulate actual user events using jQuery or native element trigger functions. For example, if you have a text input and you don't want the user to be able to add a character, you can call e.preventDefault()
with the jQuery-normalised event object on the keydown
event. However, there is no way to programatically verify this test scenario.
The following test passes even without the call to preventDefault
because the jQuery keydown trigger isn't a "real" event.
input.val('test').trigger(jQuery.Event({
which: 68
});
expect(input).toHaveValue('test');
Without the correct code, this test should fail because the input should have a value of 'testd' (68 is the character code for 'd').
Does anyone know any methods or libraries to simulate real browser UI events?
Simulate real event is quite complicated. You must first determine which type of event you need and create it with document.createEvent
. Then call different init*Event
to initialize the event object. Finally, use element.dispatchEvent
to dispatch the event to the target object.
这篇关于模拟 TDD JavaScript 的用户输入的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:模拟 TDD JavaScript 的用户输入


- 在不使用循环的情况下查找数字数组中的一项 2022-01-01
- 为什么悬停在委托事件处理程序中不起作用? 2022-01-01
- 我不能使用 json 使用 react 向我的 web api 发出 Post 请求 2022-01-01
- 使用 iframe URL 的 jQuery UI 对话框 2022-01-01
- 如何显示带有换行符的文本标签? 2022-01-01
- 如何调试 CSS/Javascript 悬停问题 2022-01-01
- 从原点悬停时触发 translateY() 2022-01-01
- 如何向 ipc 渲染器发送添加回调 2022-01-01
- 是否可以将标志传递给 Gulp 以使其以不同的方式 2022-01-01
- 为什么我的页面无法在 Github 上加载? 2022-01-01