Wenn ich zwei divs habe (z-index ist nicht zugewiesen), einen Layer über den over, kann ich den Verweis auf das obere div verwenden, um herauszufinden, welches div darunter ist?
Soweit die DOM-Struktur geht, wären diese zwei divs Geschwister. aber visuell sind sie aufeinander gestapelt.
Hier ist ein Beispiel:
%Vor%was dazu führt:
Also versuche ich herauszufinden, wann das schwarze div, box2, eine Möglichkeit hat, box1 in jquery zurückzugeben (Selektoren zu verwenden), weil box1 unter box2 ist und jquery verwendet.
Soweit ich weiß, gibt es dafür keinen Selektor. Sie könnten wahrscheinlich eine Funktion schreiben, um dies zu tun. Ich würde über jedes Element, das dem fraglichen div vorausgeht, iterieren und prüfen, ob sich die Begrenzungsbox im gewünschten div befindet.
Der einzige Weg, wie Sie es im Beispielfall haben, besteht darin, eine andere DIV-Schicht übereinander zu legen, wenn sie im DOM dahinter steht. Also, Ihre einfache Antwort ist, dass jedes Div über ein anderes div ist, wenn es danach in der DOM-Struktur kommt. Bitte geben Sie ein anschaulicheres Beispiel an, wenn dies nicht ausreicht.
Sie können veranschaulichen, dass dies funktioniert, indem Sie versuchen, DIV1 einen positiven Rand hinzuzufügen. Sie werden bemerken, dass es DIV2 nach unten kickt. DIV2 wird jedoch, wenn ein negativer Rand gegeben wird, über DIV1 "schichten". In Ihrem Szenario, das Margen und Divs ohne Z-Index oder andere Positionierungsmethoden verwendet, ist es für DIV1 nicht möglich, DIV2 zu überlappen.
BEARBEITEN basierend auf Kommentaren:
Der Prozess, herauszufinden, ob zwei Elemente denselben Raum einnehmen, ist ein anderes Spiel. Ein allgemeiner Ablauf Ihrer Methode wäre, die Koordinatenposition für Ihren Anker zu ermitteln und dessen Breite und Höhe zu ermitteln. Durchlaufen Sie dann alle Divs und prüfen Sie, ob die Position des Ankers mit einer seiner Koordinaten übereinstimmt. Wenn es mehrere divs überlappt, nehmen Sie das letzte im DOM, da es über dem anderen liegt.
Bitte zwing mich nicht, ein Codebeispiel zu schreiben. :)
Tags und Links jquery