HTML5 ネイティブのドラッグ アンド ドロップを使用しています。
親コンテナに対するドラッグ可能な要素の位置を見つけるのに問題があります。
タスクの概要
「位置:相対」divがあり、「ドロップ可能な領域」と見なされます。この div 内には、ドラッグ可能としてマークした「位置: 絶対」画像要素がいくつかあります。これらの画像をユーザーが自由に動かせるようにしたい。
要素の位置を設定するために、「dragend」にリスナーがいます。
end top / left 変数は、ピクセルではなくパーセンテージ ベースである必要があります。
現在の試行
以下に私の試みを示します。
draggable.addEventListener('dragend', function (event) {
event.preventDefault();
//Gets the position of the two elements relative to the viewport
var droppableBoundingRect = droppable.getBoundingClientRect();
//Establishes the percentage using the droppable height and width
var draggableXPercentage = ((event.clientX - droppableBoundingRect.left) / droppable.clientWidth) * 100;
var draggableYPercentage = ((event.clientY - droppableBoundingRect.top) / droppable.clientHeight) * 100;
//Set the positional elements of the draggable element
event.target.style.top = draggableYPercentage + "%";
event.target.style.left = draggableXPercentage + "%";
}, false);
そして、ここに私が望んでいたことのJSFiddleがあり、各セグメントが何をすることを期待していたかを示すコメントが付いています:
https://jsfiddle.net/oL8yd9Lr/
たぶん、私は間違った木、間違った森を探しているのでしょう。ガイダンスをいただければ幸いです。