Selenium拖放功能如何在后台运行?

时间:2019-06-28 18:56:15

标签: python-3.x selenium automation drag-and-drop

我正在尝试在我的简单html网站(保存在文件中)上自动执行拖放功能。如果将图像手动拖动到拖动框中,则拖放功能将起作用。但是,如果我尝试使用Python和Selenium复制相同的流程,则图像不会拖动到目标元素。拖放在引擎盖下到底如何工作?我是否在html文件中缺少某些内容?我确定我的Selenium代码正确,并且可以在其他网站上使用。

source_element = driver.find_element_by_id('image')
target_element = driver.find_element_by_id('drag-box')
ActionChains(driver).drag_and_drop(source_element, target_element).perform()

<head>

    <title>Test Site</title>

    <style>

        #drag-box, #dummy-box {
            width: 300px;
            height: 300px;
            padding: 10px;
            border: 1px solid;
            color: #aaaaaa;
            float: left;
        }

    </style>

    <script>

        function allowDrop(event) {
            event.preventDefault();
        }

        function drag(event) {
            event.dataTransfer.setData("image", event.target.id);
        }

        function drop(event) {
            event.preventDefault();
            var data = event.dataTransfer.getData("image");
            event.target.appendChild(document.getElementById(data));
        }

    </script>

</head>

<body>

    <header class="header-content">

        <h1>Welcome to the site!</h1>

    </header>

    <main class="main-content">

        <img id="image" src="test-image.png" draggable="true" ondragstart="drag(event)">

    </main>

    <div id="dummy-box"></div>
    <div id="drag-box" ondrop="drop(event)" ondragover="allowDrop(event)"></div>

</body>

</html>

在浏览器中打开了文件并找到了元素,但是执行拖放操作没有任何反应。我在Firefox和Chrome上都尝试过。另外,浏览器和网络驱动程序都是最新的。

0 个答案:

没有答案