我要的效果如下:csdn不支持图片  只能这么描述 左表格(下面是数据列)        |||  中间|||                    右表格(为空) 
待装车货物列表区                                            已装车货物列表区 
----------------------------------------------------------------- 
编号  姓名  货物    件数            
1    A    鞋子    10          按钮A(>>)            
2    B    茶叶    9  
3    c    鞋架    3          按钮B( < <)  
4    ...  ....    ....                      
双击左表格中的某一行  把它移动到右表格  如果右表格有数据  也可以移动到左边,要支持全选,支持按住shift、alt 移动 
就像附件中的列表框所示的效果  但是只不过把列表框换成表格的形式,或者也可以在列表框中嵌入像左表格那样的形式也可以!!
http://topic.csdn.net/u/20090507/10/ae5e7cb5-8691-432d-ae8a-d99084079f8f.html

解决方案 »

  1.   

    单击行, 选中, 点击>> << 会移动选中的行,
    双击行, 直接移动<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title>无标题文档</title>
    <style type="text/css">
    html, body{
    font-size:12px;
    }
    table{
    border-collapse:collapse;
    }
    </style>
    <script type="text/javascript">
    function $(id){
    return document.getElementById(id);
    }
    function getTable(row){
    while(row && row.tagName.toLowerCase() != "table"){
    row = row.parentNode;
    }
    return row;
    }
    function clickRow(row){
    if(row.style.backgroundColor == ""){
    row.style.backgroundColor = "#EEE";
    }else{
    row.style.backgroundColor = "";
    }
    }
    function dblclickRow(row){
    row.style.backgroundColor = "";
    moveRow(row);
    }
    function moveRow(row){
    var ts = getTable(row);
    var td = null;
    if(ts.id == "tbSource"){
    td = $("tbDest");
    }else{
    td = $("tbSource");
    }
    td.getElementsByTagName("tbody")[0].appendChild(row);
    }
    function moveTable(id){
    var tb = $(id);
    var len = tb.rows.length;
    for(var i=len-1; i>=0; i--){
    if(tb.rows[i].style.backgroundColor != ""){
    tb.rows[i].style.backgroundColor = "";
    moveRow(tb.rows[i]);
    }
    }
    }
    window.onload = function(){
    var tbSource = $("tbSource");
    for(var i=0; i<tbSource.rows.length; i++){
    tbSource.rows[i].onclick = function(){
    clickRow(this);
    };
    tbSource.rows[i].ondblclick = function(){
    dblclickRow(this);
    };
    }
    };
    </script>
    </head><body>
    <table width="600" border="0" cellspacing="0" cellpadding="0">
      <tr>
        <td align="center" valign="top"><table width="260" border="1" cellspacing="0" cellpadding="6" id="tbSource">
          <tr>
            <td bgcolor="#CCCCCC"><strong>ID</strong></td>
            <td bgcolor="#CCCCCC"><strong>姓名</strong></td>
            <td bgcolor="#CCCCCC"><strong>货物</strong></td>
            <td bgcolor="#CCCCCC"><strong>件数</strong></td>
          </tr>
          <tr>
            <td>1</td>
            <td>A</td>
            <td>D</td>
            <td>5</td>
          </tr>
          <tr>
            <td>2</td>
            <td>B</td>
            <td>E</td>
            <td>87</td>
          </tr>
          <tr>
            <td>3</td>
            <td>C</td>
            <td>F</td>
            <td>4</td>
          </tr>
        </table></td>
        <td align="center"><input type="button" name="btn1" id="btn1" value=" &gt;&gt; " onclick="moveTable('tbSource');" /><br /><br />
        <input type="button" name="btn2" id="btn2" value=" &lt;&lt; " onclick="moveTable('tbDest');" /></td>
        <td align="center" valign="top">
        <table width="260" border="1" cellspacing="0" cellpadding="6" id="tbDest">
          <tr>
            <td bgcolor="#CCCCCC"><strong>ID</strong></td>
            <td bgcolor="#CCCCCC"><strong>姓名</strong></td>
            <td bgcolor="#CCCCCC"><strong>货物</strong></td>
            <td bgcolor="#CCCCCC"><strong>件数</strong></td>
          </tr>
        </table></td>
      </tr>
    </table></body>
    </html>
      

  2.   

    Free_Wind22 真不愧高手  这就是我要的效果  搞了我三天啦