我正在尝试在我的简单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上都尝试过。另外,浏览器和网络驱动程序都是最新的。