【问题标题】:How to trigger click on a button如何触发点击按钮
【发布时间】:2017-04-11 03:20:32
【问题描述】:

我有this page。我需要使用 AngularJS 触发单击此页面上的立即购买按钮。

我已经尝试了这些方法来点击内容脚本(myscript.js)中的“立即购买”,但不起作用:

   angular.element($('ul form button:contains("BUY NOW")').get(0)).triggerHandler('click');

       $('ul form button:contains("BUY NOW")').get(0).click();

        $('ul form button:contains("BUY NOW")').get(0).dispatchEvent(new MouseEvent('click', {
            'view': window,
            'bubbles': true,
            'cancelable': true
        }));

manifest.json 看起来像这样:

"content_scripts": [
        {
            "run_at": "document_end",
            "all_frames": false,
            "matches": ["*://www.flipkart.com/*"],
            "css": [ "jqueryui/jquery-ui.css", "js/slidenavi/sidenavi-right.css","main.css", "js/bootstrap-switch-master/dist/css/bootstrap3/bootstrap-switch.min.css"],
            "js": ["jquery-2.1.4.min.js", "jqueryui/jquery-ui.min.js","js/angular.min.js", "js/jquery.cookie.js", "jqueryui/jquery-ui.min.js","js/slidenavi/SideNavi.js", "client_server_common.js", "user-selections.js",
                "jquery.countdown.min.js", "js/bootstrap-switch-master/dist/js/bootstrap-switch.min.js", "js/cryptojs/rollups/md5.js",  "common.js",
                "myscript.js"
            ]
        }
    ],

有什么办法让它发挥作用?

【问题讨论】:

    标签: google-chrome-extension firefox-addon-webextensions


    【解决方案1】:

    试试这个代码;它通过在按钮中心触发的快速连续的 mousedown、mouseup 和 click 事件来模拟鼠标左键单击元素:

    var simulateMouseEvent = function(element, eventName, coordX, coordY) {
      element.dispatchEvent(new MouseEvent(eventName, {
        view: window,
        bubbles: true,
        cancelable: true,
        clientX: coordX,
        clientY: coordY,
        button: 0
      }));
    };
    
    var theButton = document.querySelector('ul form button');
    
    var box = theButton.getBoundingClientRect(),
            coordX = box.left + (box.right - box.left) / 2,
            coordY = box.top + (box.bottom - box.top) / 2;
    
    simulateMouseEvent (theButton, "mousedown", coordX, coordY);
    simulateMouseEvent (theButton, "mouseup", coordX, coordY);
    simulateMouseEvent (theButton, "click", coordX, coordY);
    

    【讨论】:

    • 我有另一个选择元素,但这种技术不起作用。即使选择了一个选项,它仍然要求选择一个选项。还有什么事情要做吗?
    • 您无法使用 Javascript 打开选择元素的选项列表。见this answer
    【解决方案2】:

    Vanilla JS 怎么样,没有人禁止?

    比如“onlick/click”?

    function ae(a,b,c) {
     if (a.addEventListener)
         a.addEventListener (b,c,false);
     else if (a.attachEvent)
         a.attachEvent ('on'+b,c); 
    }
    function re(a,b,c) {
     if (a.removeEventListener) 
        a.removeEventListener (b,c,false);
     if (a.detachEvent)
        a.detachEvent ('on'+b,c); 
    }
    

    【讨论】:

    • 它是什么以及如何使用它?
    猜你喜欢
    • 1970-01-01
    • 2012-08-06
    • 1970-01-01
    • 1970-01-01
    • 2020-09-14
    • 2017-06-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多