How to simulate a mouse click using JavaScript?
我知道
我在StackOverflow的某个地方找到了这段代码,但是我不知道如何使用它:(
1 2 3 4 5 6 7 8 9 10 11 12 | function contextMenuClick() { var element= 'button' var evt = element.ownerDocument.createEvent('MouseEvents'); evt.initMouseEvent('contextmenu', true, true, element.ownerDocument.defaultView, 1, 0, 0, 0, 0, false, false, false, false, 1, null); element.dispatchEvent(evt); } |
如何使用JavaScript触发鼠标单击事件?
(修改后的版本使之无需prototype.js即可工作)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 | function simulate(element, eventName) { var options = extend(defaultOptions, arguments[2] || {}); var oEvent, eventType = null; for (var name in eventMatchers) { if (eventMatchers[name].test(eventName)) { eventType = name; break; } } if (!eventType) throw new SyntaxError('Only HTMLEvents and MouseEvents interfaces are supported'); if (document.createEvent) { oEvent = document.createEvent(eventType); if (eventType == 'HTMLEvents') { oEvent.initEvent(eventName, options.bubbles, options.cancelable); } else { oEvent.initMouseEvent(eventName, options.bubbles, options.cancelable, document.defaultView, options.button, options.pointerX, options.pointerY, options.pointerX, options.pointerY, options.ctrlKey, options.altKey, options.shiftKey, options.metaKey, options.button, element); } element.dispatchEvent(oEvent); } else { options.clientX = options.pointerX; options.clientY = options.pointerY; var evt = document.createEventObject(); oEvent = extend(evt, options); element.fireEvent('on' + eventName, oEvent); } return element; } function extend(destination, source) { for (var property in source) destination[property] = source[property]; return destination; } var eventMatchers = { 'HTMLEvents': /^(?:load|unload|abort|error|select|change|submit|reset|focus|blur|resize|scroll)$/, 'MouseEvents': /^(?:click|dblclick|mouse(?:down|up|over|move|out))$/ } var defaultOptions = { pointerX: 0, pointerY: 0, button: 0, ctrlKey: false, altKey: false, shiftKey: false, metaKey: false, bubbles: true, cancelable: true } |
您可以像这样使用它:
1 | simulate(document.getElementById("btn"),"click"); |
请注意,作为第三个参数,您可以传入'options'。您未指定的选项取自defaultOptions(请参见脚本底部)。因此,例如,如果您想指定鼠标坐标,则可以执行以下操作:
1 | simulate(document.getElementById("btn"),"click", { pointerX: 123, pointerY: 321 }) |
您可以使用类似的方法来覆盖其他默认选项。
应归功于kangax。这是原始来源(特定于prototype.js)。
这是一个纯JavaScript函数,它将模拟对目标元素的点击(或任何鼠标事件):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | function simulatedClick(target, options) { var event = target.ownerDocument.createEvent('MouseEvents'), options = options || {}, opts = { // These are the default values, set up for un-modified left clicks type: 'click', canBubble: true, cancelable: true, view: target.ownerDocument.defaultView, detail: 1, screenX: 0, //The coordinates within the entire page screenY: 0, clientX: 0, //The coordinates within the viewport clientY: 0, ctrlKey: false, altKey: false, shiftKey: false, metaKey: false, //I *think* 'meta' is 'Cmd/Apple' on Mac, and 'Windows key' on Win. Not sure, though! button: 0, //0 = left, 1 = middle, 2 = right relatedTarget: null, }; //Merge the options with the defaults for (var key in options) { if (options.hasOwnProperty(key)) { opts[key] = options[key]; } } //Pass in the options event.initMouseEvent( opts.type, opts.canBubble, opts.cancelable, opts.view, opts.detail, opts.screenX, opts.screenY, opts.clientX, opts.clientY, opts.ctrlKey, opts.altKey, opts.shiftKey, opts.metaKey, opts.button, opts.relatedTarget ); //Fire the event target.dispatchEvent(event); } |
这是一个工作示例:http://www.spookandpuff.com/examples/clickSimulation.html
您可以模拟对DOM中任何元素的点击。
您可以将对象传递到
我已经在Firefox,Safari和Chrome中进行了测试。我不确定InternetExplorer可能需要特殊处理。
一种模拟鼠标单击的更简单,更标准的方法是直接使用事件构造函数创建事件并进行调度。
Though the
MouseEvent.initMouseEvent() method is kept for backward compatibility, creating of a MouseEvent object should be done using theMouseEvent() constructor.
1 2 3 4 5 6 7 8 | var evt = new MouseEvent("click", { view: window, bubbles: true, cancelable: true, clientX: 20, /* whatever properties you want to give it */ }); targetElement.dispatchEvent(evt); |
演示:http://jsfiddle.net/DerekL/932wyok6/
这适用于所有现代浏览器。对于包括IE在内的旧版浏览器,不幸的是必须使用
1 2 3 4 5 6 | var evt = document.createEvent("MouseEvents"); evt.initMouseEvent("click", canBubble, cancelable, view, detail, screenX, screenY, clientX, clientY, ctrlKey, altKey, shiftKey, metaKey, button, relatedTarget); targetElement.dispatchEvent(evt); |
从Mozilla开发人员网络(MDN)文档中,您正在寻找HTMLElement.click()。您可以在此处找到更多事件。
根据德里克的回答,我验证了
1 2 | document.getElementById('testTarget') .dispatchEvent(new MouseEvent('click', {shiftKey: true})) |
即使使用键修饰符也可以正常工作。据我所知,这不是一个过时的API。您也可以在此页面上进行验证。
您可以使用elementFromPoint:
1 | document.elementFromPoint(x, y); |
所有浏览器均支持:https://caniuse.com/#feat=element-from-point
JavaScript代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | //this function is used to fire click event function eventFire(el, etype){ if (el.fireEvent) { el.fireEvent('on' + etype); } else { var evObj = document.createEvent('Events'); evObj.initEvent(etype, true, false); el.dispatchEvent(evObj); } } function showPdf(){ eventFire(document.getElementById('picToClick'), 'click'); } |
HTML代码
1 2 | <img id="picToClick" data-toggle="modal" data-target="#pdfModal" src="img/Adobe-icon.png" ng-hide="1===1"> <button onclick="showPdf()">Click me</button> |