无忧脚本 » 经典代码、教程资源库 » 【共享】拖动改变次序的XML树型菜单

2004-5-25 04:41 biyuan
【共享】拖动改变次序的XML树型菜单

[code]<html>
<head>
<title>拖动改变次序的XML树型菜单</title>
<style>
UNKNOWN {
        TEXT-DECORATION: none
}
A:visited {
        TEXT-DECORATION: none
}
A:hover {
        COLOR: #ff0000; TEXT-DECORATION: none
}
A:link {
        TEXT-DECORATION: none
}
BODY {
        FONT-SIZE: 9pt; COLOR: #000000; FONT-FAMILY: "MS Shell Dlg", "Tahoma", "sans-serif"; TEXT-DECORATION: none
}
TR {
        FONT-SIZE: 9pt; FONT-FAMILY: MS Shell Dlg, Tahoma,sans-serif
}
TD {
        FONT-WEIGHT: normal; FONT-SIZE: 9pt; FONT-FAMILY: MS Shell Dlg,Tahoma, sans-serif
}
FORM {
        FONT-SIZE: 9pt; FONT-FAMILY: MS Shell Dlg,tahoma,宋体
}
.black {
        FONT-SIZE: 9pt; COLOR: #000000
}
.white {
        FONT-SIZE: 9pt; COLOR: #ffffff
}
.red {
        FONT-SIZE: 9pt; COLOR: #ff0000
}
.green {
        FONT-SIZE: 9pt; COLOR: #009900
}
.c990000 {
        FONT-SIZE: 9pt; COLOR: #990000
}
.cFF9900 {
        FONT-SIZE: 9pt; COLOR: #ff9900
}
.c333399 {
        FONT-SIZE: 9pt; COLOR: #333399
}
.blue {
        FONT-SIZE: 9pt; COLOR: #0000ff
}
.blue1 {
        FONT-SIZE: 9pt; COLOR: #3300cc
}
.gray {
        FONT-SIZE: 9pt; COLOR: #666666
}
.row {
        LINE-HEIGHT: 15pt
}
.bottom {
        BORDER-RIGHT: #665b8e 1px solid; BORDER-TOP: #ffffff 1px solid; FONT-SIZE: 9pt; BORDER-LEFT: #ffffff 1px solid; COLOR: #000000; BORDER-BOTTOM: #665b8e 1px solid; FONT-FAMILY: "宋体"; HEIGHT: 18px; BACKGROUND-COLOR: #cccccc
}

.editbox2 {
        PADDING-RIGHT: 1px; PADDING-LEFT: 1px; FONT-SIZE: 9pt; PADDING-BOTTOM: 1px; CURSOR: text; COLOR: #000000; PADDING-TOP: 1px; FONT-FAMILY: 宋体; BACKGROUND-COLOR: #dbdbdb
}
.size {
        FONT-SIZE: 9px; FONT-FAMILY: "Verdana", "Arial", "Helvetica", "sans-serif"
}

</style>
<link rel="stylesheet" type="text/css" href="css/style.css">
<SCRIPT>
self.moveTo(0,0)
self.resizeTo(screen.availWidth,screen.availHeight)
</SCRIPT>
</head>
<body bgcolor="#FFFFFF" ><div align="center">
<center>
    <html>
<body bgcolor="#FFFFFF">

</html> <br>
    <table cellspacing="0" width="98%" border="1" bordercolorlight="#000000" cellpadding="0">
  <tr bgcolor="#CCCCCC">
    <td width="100%" height="20" class="title" background="IMAGES/mmto.gif">
      <div align="center" class="title"><b><font color="#000000">标题:</font> </b>拖动改变次序的XML树型菜单
      </div>
    </td>
  </tr>
  <tr>
        
            
              
<HTML xmlns:ie><HEAD><TITLE>这是一个可以拖动改变次序的XML树型菜单</TITLE>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<style>
ie\:tree {
        DISPLAY: block
}
ie\:treeitem {
        BORDER-TOP: white 2px solid; DISPLAY: block; ; FONT-WEIGHT: expression(this.children.length > 1 ? 'bold' : 'normal'); VISIBILITY: inherit; MARGIN-LEFT: 20px; OVERFLOW: hidden; WIDTH: 100%
}
ie\:label {
        DISPLAY: inline; CURSOR: hand
}
        ie\:label {behavior:url(tree2.htc)}       

UNKNOWN {
        TEXT-DECORATION: none
}
A:visited {
        TEXT-DECORATION: none
}
A:hover {
        COLOR: #ff0000; TEXT-DECORATION: none
}
A:link {
        TEXT-DECORATION: none
}
BODY {
        FONT-SIZE: 9pt; COLOR: #000000; FONT-FAMILY: "MS Shell Dlg", "Tahoma", "sans-serif"; TEXT-DECORATION: none
}
TR {
        FONT-SIZE: 9pt; FONT-FAMILY: MS Shell Dlg, Tahoma,sans-serif
}
TD {
        FONT-WEIGHT: normal; FONT-SIZE: 9pt; FONT-FAMILY: MS Shell Dlg,Tahoma, sans-serif
}
FORM {
        FONT-SIZE: 9pt; FONT-FAMILY: MS Shell Dlg,tahoma,宋体
}
.black {
        FONT-SIZE: 9pt; COLOR: #000000
}
.white {
        FONT-SIZE: 9pt; COLOR: #ffffff
}
.red {
        FONT-SIZE: 9pt; COLOR: #ff0000
}
.green {
        FONT-SIZE: 9pt; COLOR: #009900
}
.c990000 {
        FONT-SIZE: 9pt; COLOR: #990000
}
.cFF9900 {
        FONT-SIZE: 9pt; COLOR: #ff9900
}
.c333399 {
        FONT-SIZE: 9pt; COLOR: #333399
}
.blue {
        FONT-SIZE: 9pt; COLOR: #0000ff
}
.blue1 {
        FONT-SIZE: 9pt; COLOR: #3300cc
}
.gray {
        FONT-SIZE: 9pt; COLOR: #666666
}
.row {
        LINE-HEIGHT: 15pt
}
.bottom {
        BORDER-RIGHT: #665b8e 1px solid; BORDER-TOP: #ffffff 1px solid; FONT-SIZE: 9pt; BORDER-LEFT: #ffffff 1px solid; COLOR: #000000; BORDER-BOTTOM: #665b8e 1px solid; FONT-FAMILY: "宋体"; HEIGHT: 18px; BACKGROUND-COLOR: #cccccc
}
.editbox1 {
        FONT-SIZE: 9pt; COLOR: #000000; FONT-FAMILY: 宋体; HEIGHT: 18px; BACKGROUND-COLOR: #dbdbdb
}
.editbox3 {
        FONT-SIZE: 9pt; COLOR: #000000; FONT-FAMILY: 宋体; HEIGHT: 18px; BACKGROUND-COLOR: #ffffff
}
.editbox2 {
        PADDING-RIGHT: 1px; PADDING-LEFT: 1px; FONT-SIZE: 9pt; PADDING-BOTTOM: 1px; CURSOR: text; COLOR: #000000; PADDING-TOP: 1px; FONT-FAMILY: 宋体; BACKGROUND-COLOR: #dbdbdb
}
.size {
        FONT-SIZE: 9px; FONT-FAMILY: "Verdana", "Arial", "Helvetica", "sans-serif"
}
A.yellow:active {
        COLOR: #ffffff; TEXT-DECORATION: none
}
A.yellow:visited {
        COLOR: #ffffff; TEXT-DECORATION: none
}
A.yellow:link {
        COLOR: #ffffff; TEXT-DECORATION: none
}
A.yellow:hover {
        COLOR: #ffff33; TEXT-DECORATION: none
}
</style>
<SCRIPT language=JavaScript>
<!--

function MM_goToURL() { //v3.0
  var i, args=MM_goToURL.arguments; document.MM_returnValue = false;
  for (i=0; i<(args.length-1); i+=2) eval(args[i]+".location='"+args[i+1]+"'");
}
function JM_cc(ob){
var obj=MM_findObj(ob); if (obj) {
obj.select();js=obj.createTextRange();js.execCommand("Copy");}
}

function MM_findObj(n, d) { //v4.0
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && document.getElementById) x=document.getElementById(n); return x;
}
//-->
</SCRIPT>

<META content="MSHTML 6.00.2600.0" name=GENERATOR></HEAD>
<BODY bgColor=#ffffff leftMargin=0 topMargin=0 onload=initial() style="FONT-SIZE: 12px; FONT-FAMILY: verdana">
<TABLE cellSpacing=0 cellPadding=0 width=600 align=center border=0>
  <TBODY>
  <TR bgColor=#7285cf>
    <TD width=10 height=18>&nbsp;</TD>
    <TD class=white width=590 bgColor=#7285cf height=18>这是一个可以拖动改变次序的XML树型菜单</TD>
  </TR>
  <TR bgColor=#e7e7e7>
    <TD width=10>&nbsp;</TD>
    <TD class=row width=590 bgColor=#e7e7e7
      height=30>这是一个可以拖动改变次序的XML树型菜单</TD>
  </TR>
  <TR bgColor=#f2f2f2>
    <TD width=10 bgColor=#f2f2f2>&nbsp;</TD>
    <TD width=590 bgColor=#f2f2f2 height=70>&nbsp;
        <H3>Animating Expanding/Collapsing List with Drag/Drop <I>e.c.
listus</I></H3><ie:tree id=TheTree>
<ie:treeitem><ie:label id=Label1>1.0 FirstSet</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><!--S-->
<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><!--  E-->

<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
function dragstart() {
  var e;
  e = window.event.srcElement;
  if (e.tagName != "label")
    return false;

  dragElement = e.parentElement;
}

// method called as we start drag/drop

// 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> </TD>
  </TR></TBODY></TABLE><BR>
[/code]

2005-4-1 10:12 hgamezoom
不太明白……

2005-4-11 23:05 zaz858
很方便哦!

2005-4-19 21:33 lovewh
不 是很好 啊 ~~~

2005-4-19 21:57 lqfndskf
好东西一起用撒。

2005-4-19 21:57 lqfndskf
看看。哈哈。

2005-4-19 21:58 lqfndskf
其实我也在好东西给大家看。但是不知道怎么把他传上来。

2005-4-19 21:58 lqfndskf
有那个大侠能告诉我怎么上传吗?

2005-4-27 14:39 max
不错,应该会有用处。

2005-11-11 16:25 percy
look 一下 ^_^

2005-11-25 17:23 折翼恶魔
看不懂

2007-12-16 15:45 zjacai
怎么看着代码这么乱, 有好多<html>的标签哎

怎么好像大家都看提挺明白的! :L  希望能解释一下啊,谢谢了

2008-3-8 22:20 shooter
为什么非要搞窗口自动放大呀
最烦这样的了

页: [1]


Powered by Discuz! Archiver 5.5.0  © 2001-2006 Comsenz Inc.