我想請求下面的幫助。基本上,我每次按下按鈕時都會嘗試新建一個<div>
。然後,我想添加一個函數,使得每個新的<div>
能夠被拖動和移動,當我點擊它並且當我釋放鼠標時它會下降(每個新的<div>
應該單獨移動)。我嘗試了很多東西,但他們似乎都不太好。我得到的結果是,只有第一個<div>
正在移動,或者所有<div>
一起移動。我沒有添加我的移動功能,因爲它沒有很好的安排(很難理解,因爲我嘗試了很多東西)。我也不允許使用JQuery。如何讓每個新的div可拖動?
可以請您指導我做什麼?謝謝。
<html>
<body>
<button id="mybutton">Create a new moveabl div</button>
<script>
var create = document.createElement("div");
create.id = "dragm2";
document.body.appendChild(create);
var count = 0;
var text = document.createTextNode("mu yu ");
document.getElementById("mybutton").addEventListener("click", function() {
count++;
var create = document.createElement("div");
create.id = "dragme" + count;
create.style.background = "green";
create.style.height = "170px";
create.style.width= "70px";
create.appendChild(text);
document.body.appendChild(create);
});
document.body.addEventListener("click", function(event) {
console.log(event.target.nodeName);
console.log(event.target.id);
var movenow = event.target.id;
if (movenow !== null && event.target.nodeName !== "BUTTON") {
document.getElementById(movenow).addEventListener('mousedown', hold, false);
document.body.addEventListener('mouseup', release, false);
function hold() {
document.getElementById(movenow).addEventListener('mousemove', move, true);
document.body.addEventListener('mousemove', move, true);
}
// ==> On Realease Function <==
function release() {
document.getElementById(movenow).removeEventListener('mousemove', move, true);
document.body.removeEventListener('mousemove', move, true);
}
function move(event) {
var epY = event.clientY;
var epX = event.clientX;
if (document.querySelectorAll("input[name='revertxy']:checked").length >= 1) {
epY = event.clientX;
epX = event.clientY;
}
event.target.style.position = 'absolute';
event.target.style.top = epY + 'px';
event.target.style.left = epX + 'px';
}
}
});
</script>
</body>
</html>
你需要使用的可拖動屬性:https://developer.mozilla.org/en-US/docs /網絡/ HTML/Global_attributes /拖動。你發佈的代碼甚至是如何使一個div可拖動? – floor
你可以重新創建你在jsFiddle裏面試過的東西嗎?您分享的代碼並不一定有幫助,因爲我們無法重現該問題。 –