tree.htm < html xmlns:ie > < head > <!-- TOOLBAR_START --> <!-- TOOLBAR_EXEMPT --> <!-- TOOLBAR_END --> < style > ie:tree ... {display: block;} ie:treeitem ... {font-weight: expression(this.children.length > 1 ? 'bold' : 'normal'); border-top: 2px solid white;display: block; margin-left: 20px; visibility: inherit; overflow: hidden; width: 100%} ie:label ... {display: inline; cursor: hand} </ style > </ head > < body style = " font-family: verdana; font-size: 12px " > < h3 > 可以拖动的tree </ h3 > < ie:tree id = TheTree > < ie:treeitem >< ie:label id = Label1 > 1.0 First Set </ ie:label > < ie:treeitem >< ie:label > 1.1 Megalosaurus </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 1.2 Iguanodon </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 1.3 Hylaeosaurus </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 1.4 Tyrannosaurus rex </ ie:label ></ ie:treeitem > </ ie:treeitem > < ie:treeitem >< ie:label > 2.0 Later Set </ ie:label > < ie:treeitem >< ie:label > 2.1 Mammoths </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.2 Mastodons </ ie:label > < ie:treeitem >< ie:label > 2.2 . 1 Plesiosaurs </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.2 . 2 Ichthyosaurs </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.2 . 3 Dimetrodon </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.2 . 4 Sinapsid </ ie:label ></ ie:treeitem > </ ie:treeitem > < ie:treeitem >< ie:label > 2.3 Stegosaurus </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.4 Apatosaurus </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.5 Mammals </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.6 Tetrapods </ ie:label > < ie:treeitem >< ie:label > 2.6 . 1 Amphibians </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.6 . 2 Whales </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.6 . 3 Crocodiles </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.6 . 4 Sea Turtles </ ie:label ></ ie:treeitem > </ ie:treeitem > < ie:treeitem >< ie:label > 2.7 Late Permian </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 2.8 Mesozoic </ ie:label ></ ie:treeitem > </ ie:treeitem > < ie:treeitem >< ie:label > 3.0 Archosaurs </ ie:label > < ie:treeitem >< ie:label > 3.1 Mandibular fenestra </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 3.2 Pointed Snout </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 3.3 Theocodant Tooth Implantation </ ie:label ></ ie:treeitem > < ie:treeitem >< ie:label > 3.4 Modified Ankle </ ie:label ></ ie:treeitem > </ ie:treeitem > < ie:treeitem >< ie:label > 4.0 Mesozoic </ ie:label > < ie:treeitem >< ie:label > 4.1 Middle Animals </ ie:label ></ ie:treeitem > </ ie:treeitem > </ ie:tree > < script > // variables for drag/drop var dragElement = null ; var dropElement = null ; var currOver = null ; // variables for expanding/collapsing var flyCount = 5 ; var msecs = 5 ; var currCount = 0 ; // event handler hookup TheTree.onmousedown = preselect; TheTree.ondragstart = dragstart; TheTree.ondragend = dragend; TheTree.ondragenter = dragover; TheTree.ondragover = dragover; TheTree.ondragend = dragend; TheTree.ondrop = dragdrop; document.onclick = click; // drag/drop code // method called as we start drag/drop function dragstart() ... { var e; e = window.event.srcElement; if (e.tagName != "label") return false; dragElement = e.parentElement; } // called as we mouse over - note that there is special handling for dragover code // as dragleave doesn't track the toElement/fromElement as mouseover/mouseout does function dragover() ... { if (window.event.srcElement.tagName != "treeitem") return; if (!dragElement.contains(window.event.srcElement)) ...{ if (currOver) ...{ currOver.style.borderTopColor = ""; } currOver = window.event.srcElement; window.event.srcElement.style.borderTopColor = "black"; event.returnValue = false; } } // called when drag is ended - always function dragend() ... { if (currOver) ...{ currOver.style.borderTopColor = ""; } } // called on drop function dragdrop() ... { if (currOver) ...{ currOver.style.borderTopColor = ""; } t = currOver; t.parentElement.insertBefore(dragElement, t); } // needed to select items so they can be dragged // drag drop only supported on selection and images function preselect() ... { var e; e = window.event.srcElement; if (e.tagName != "label") ...{ return; } r = document.body.createTextRange(); r.moveToElementText(e); r.select(); window.event.cancelBubble = true; } // beginning of expand/collapse code // called to handle document click, starts toggling function click() ... { if (window.event.srcElement.tagName != "label") ...{ return; } if (window.event.srcElement.parentElement.children.length > 1) ...{ toggleState(window.event.srcElement.parentElement); } } // toggles expanding/collapse state of an element - does setup function toggleState(e) ... { e.oHeight = e.scrollHeight + 2; e.style.posHeight = e.offsetHeight; if (e.scrollHeight >= e.offsetHeight) ...{ growIt(e); } else ...{ shrinkIt(e); } } // called to initiate growing an element function growIt(e) ... { currCount = 0; window.setTimeout("doGrow(" + e.uniqueID + ");", msecs); } // called to initiate shrinking an element function shrinkIt(e) ... { currCount = 0; window.setTimeout("doShrink(" + e.uniqueID + ");", msecs); } // inner loop for growing an object function doGrow(e) ... { var dh; var lineHeight = e.children[0].offsetHeight; currCount++; dh = e.oHeight / flyCount; if (e.style.posHeight != e.oHeight) ...{ e.style.posHeight += dh; } if (currCount < flyCount) ...{ window.setTimeout("doGrow(" + e.uniqueID + ");", msecs); } else ...{ e.style.height = ""; } } // inner loop for shrinking an object function doShrink(e) ... { var dh, dw; var lineHeight = e.children[0].offsetHeight; var p; currCount++; dh = (e.oHeight - lineHeight) / flyCount; e.style.posHeight -= dh; if (currCount < flyCount) ...{ window.setTimeout("doShrink(" + e.uniqueID + ");", msecs); } else ...{ e.style.posHeight = lineHeight; } } </ script > </ body > </ html >