咖啡机(K.F.J)通过本文主要向大家介绍了javascript 模拟按键,javascript按键事件,javascript 按键,javascript的执行原理,javascript原理等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
最近有个需求,需要在页面上面自动点击、输入、提交。
用以模拟真实用户的操作行为,可以通过直接执行某个元素绑定的事件,来执行操作。
也可以创建事件,再派发事件,执行操作。关于事件的更多细节,可以参考《JavaScript中事件处理》
1、模拟MouseEvent中的click事件,x与y位置随机点击
2、模拟TouchEvent中的touchstart和touchmove,用scroll来做滑动效果
3、模拟FocusEvent,聚焦到屏幕中的输入框内

一、鼠标事件MouseEvent
MouseEvent接口指用户与指针设备( 如鼠标 )交互时发生的事件。使用此接口的常见事件包括:click,dblclick,mouseup,mousedown。
MouseEvent派生自 UIEvent,UIEvent 派生自 Event。
function random(max) {
return Math.floor(Math.random() * max);
}
function on(dom, type, fn) {
dom.addEventListener(type, fn, false);
}
on(document.body, 'click', function(e) {
console.log('click事件 x:'+e.clientX, 'y:'+e.clientY);
});
/**
* MouseEvent
* 包括事件 click,dblclick,mouseup,mousedown
*/
function mouse() {
var x = random(window.outerWidth),
y = random(window.outerHeight);
var event = new MouseEvent('click', {
bubbles: true,
cancelable: true,
view: window,
clientX: x,
clientY: y
});
console.log('click环境 x:'+x, 'y:'+y);
document.body.dispatchEvent(event);
}
mouse();
</div>
1)Event
语法如下:

typeArg:事件的名字,DOMString类型。
eventInit:
|
属性 |
选项 | 默认 | 类型 | 描述 |
| bubbles | 可选 | false | Boolean | 事件是否冒泡 |
| cancelable | 可选 | false | Boolean | 事件是否可取消 |
| scoped |
您可能想查找下面的文章:文章分类 |

