基於JS的WEB會議室預訂拖拽式圖形界面的實現

       很早之前寫的,後來由於這個功能模塊取消,最終沒有上線,所以與Server交互的那部分還沒有寫,不過那部分方案我也已經出來了,而且現在客戶端這一部分已經通過了比較完備的測試。大家看看這一部分的代碼,應該一看就懂。 那時候也不知道那麼多JS的UI庫,所以全部都是自己繪製的,界面有點簡陋,希望湊或者看吧,再就是我們這個項目是局域網項目,所以大家用的都是IE,沒有考慮跨瀏覽器的因素。發出來希望對做同樣應用的同志少走點彎路,我寫的時候,網上沒有這方面的代碼,現在有沒有就不知道了。

   網頁代碼

<%@page contentType="text/html; charset=gb2312" pageEncoding="GB2312" %>
<%@ page language="java"%>
<%@ page import="java.util.List" %>
<style>
th.timem      
{font-size: 8pt; font-family: Times New Roman;}
td.reserved   
{background-color: #FF0066}
td.free       
{background-color: #99CCFF}
td.selected   
{background-color: #ccCCFF}
</style>
<script language="JavaScript" type="text/javascript" src="timetable.js"></script>
<script>
<!--
    
var dragging=false;//是否在拖拽
    var OrignCell="";//開始格位
    var CurrentCell="";//當前格位
    var pope;
    window.onload
=function()
    
{
        
try{
            pope
=document.getElementById("pop");
            
var tp=document.getElementById('TablePosition');
            
var tt=CreateTable();
            tp.appendChild(tt);
            SetReserves();
            document.getElementById(
'2-5').className="reserved";
                document.getElementById(
'5-10').className="reserved";//for test
        }
catch(e)
        
{
            alert(e.name 
+ "" + e.message);
        }

    }

       
//設置已預訂單元
    function SetReserves()
    
{
        
//Insert the Reserved Cells Intialation by SetReserve()
        
    }

-->
</script>
<div id="pop" style="position:absolute;width:50; display: none; z-index:99; font-size: 13px; background:#FFCCFF;filter:alpha(opacity=40); border-style: solid; border-width: thin;border-color:#FF66CC; " >
<div onclick="Reserve()" style="{cursor: hand;} ">預訂</div>
<hr size=0.1 color=#FF66CC;>
<div onclick="Cancel()"style="{cursor: hand;} ">取消</div>
</div>
<div id="TablePosition"  >
</div>

 

JS代碼:

 

//創建會議室預訂情況時間表
    function CreateTable()
    
{
        
var tt=document.createElement("table");
        
var tbody=document.createElement("tbody");
        tt.onmouseout
=OutDragT;
        tbody.onmouseout
=CancleBubble;
        tt.appendChild(tbody);
        tt.border
='1';
        tt.id
='TimeTable';
        tt.cellSpacing 
="1";//???????????
        tt.borderColor="#6699ff";
        tt.align
='center';
        tt.onselectstart 
=False; 
        
for(var i=0;i<6;i++)
        
{
            
var tr=document.createElement("tr");
            
for(var j=0;j<18;j++)
            
{
                
var hd=document.createElement("td");
                hd.id
=i+'-'+j;
                hd.innerHTML
="&nbsp;";
                hd.onmousedown 
= BeginDrag;
                        hd.onmousemove 
= OnDrag;
                        hd.onmouseup 
= EndDrag;
                hd.className
="free";///for test
                hd.onmouseover=onshow;
                
if(i==0)
                
{
                    hd
=document.createElement("th");
                    hd.className
='timem';
                    hd.width
='30';
                    
if(j==0)
                    
{
                        hd.innerHTML
="&nbsp;"
                    }
else{
                        
var hour=8+Math.floor(j/2);
                        
var minutes=30*(j%2);
                        hd.appendChild(document.createTextNode(hour
+':'+minutes));
                    }

                }

                
if(j==0&&i!=0)
                
{
                    hd
=document.createElement("th");
                    hd.className
='timem';
                    hd.appendChild(document.createTextNode(
'?'+i));
                }

                tr.appendChild(hd);
            }

            tbody.appendChild(tr);
        }



        
return tt;    
    }


    
function SetReserve(id)
    
{
        document.getElementById(id)
="reserved";
    }

    
//取消事件冒泡
    function CancleBubble()
    
{
        event.cancelBubble
=true;
    }

    
//拖拽選擇開始函數
    function BeginDrag()
    
{
        
if (event.button != 1)
        
{
            
return;
        }

        OrignCell
=this.id;
        CurrentCell
=this.id;
        
if(ModifyClass())
        
{        
               dragging
=true;
        }
else{
            alert(
"????????!");
            OrignCell
="";
            CurrentCell
="";
        }

    }

   
//拖拽過程處理函數
    function OnDrag()
    
{
        
if(dragging==false||this.id==CurrentCell)
        
{
            
return;
            
        }

        CurrentCell
=this.id;
        
if(!ModifyClass())
        
{
            Reverse()
            dragging
=false;
            OrignCell
="";
                    CurrentCell
="";
            pope.style.display 
= 'none';
            alert(
"?????????????!");
            
        }
        
    }

    
//結束拖拽
    function EndDrag()
    
{
        
if(dragging==false)
        
{
            
return;
        }

        dragging
==false;
        pope.style.top
=event.clientY
        pope.style.left
=event.clientX
        pope.style.display 
= "";
    }

    
//本爲處理鼠標過界操作後作他用
    function OutDrag()
    
{    
        
if(dragging==false)
        
{
            
return;
        }

        
//???
        Reverse();
        dragging
=false;
    
    }

    
//Handler for mousemoveout of timetable
    function OutDragT()
    
{
        
var Tt=document.getElementById("TimeTable");
            
if(event.clientX<=Tt.offsetLeft||event.clientX>=(Tt.offsetLeft+Tt.offsetWidth)||event.clientY<=Tt.offsetTop||event.clientY>=(Tt.offsetTop+Tt.offsetHeight))
        
{
            OutDrag();
            window.status
="";
        }

    }

    
function False()
    
{
         
return false;
    }

    
//修正各單元格的狀態並返回結果
    function ModifyClass()
    
{
        
        Reverse();
    
        
for(var i=X1();i<=X2();i++)
        
{
            
for(var j=Y1();j<=Y2();j++)
            
{
                
var CName =document.getElementById(i+"-"+j).className;
                
if(CName.indexOf("reserved")!=-1)
                
{
                    
return false;
                }

                
if(CName.indexOf("selected")!=-1)
                
{
                    
continue;
                }

                
if(CName.indexOf("free")!=-1)
                
{
                    document.getElementById(i
+"-"+j).className="selected";
                }
                
            }

        }

        
return true;
    }

    
//返回初始狀態
    function Reverse()
    
{
        
for(var i=1;i<6;i++)
        
{
            
for(var j=1;j<18;j++)
            
{
                
var CName =document.getElementById(i+"-"+j).className;
                
if(CName.indexOf("selected")!=-1)
                
{
                    document.getElementById(i
+"-"+j).className="free";    
                }

            }
            
        }

    }

    
//取消選擇
    function Cancel()
    
{
        pope.style.display 
= 'none';
        OutDrag();
        dragging
=false;
    }

    
//預訂操作
    function Reserve()
    
{
        pope.style.display 
= 'none';
        alert(
"????!")
        dragging
=false;
    }

    
//選擇區域的橫方向小座標
    function X1()
    
{
        
var Bx,Ex;
        
var TArray=OrignCell.split('-');
        Bx
=parseInt(TArray[0]);
        TArray
=CurrentCell.split('-');
        Ex
=parseInt(TArray[0]);
        
return Bx<=Ex?Bx:Ex;
        
    }

    
//選擇區域的橫方向大座標
    function X2()
    
{
        
var Bx,Ex;
        
var TArray=OrignCell.split('-');
        Bx
=parseInt(TArray[0]);
        TArray
=CurrentCell.split('-');
        Ex
=parseInt(TArray[0]);
        
return Bx>=Ex?Bx:Ex;
    }

    
//選擇區域的縱方向小座標
    function Y1()
    
{
        
var Bx,Ex;
        
var TArray=OrignCell.split('-');
        Bx
=parseInt(TArray[1]);
        TArray
=CurrentCell.split('-');
        Ex
=parseInt(TArray[1]);
        
return Bx<=Ex?Bx:Ex;
    }

    
//選擇區域的縱方向大座標
    function Y2()
    
{
        
var Bx,Ex;
        
var TArray=OrignCell.split('-');
        Bx
=parseInt(TArray[1]);
        TArray
=CurrentCell.split('-');
        Ex
=parseInt(TArray[1]);
        
return Bx>=Ex?Bx:Ex;
    }

    
//顯示選擇情況!
    function onshow()
    
{
        window.status
="Cell:"+OrignCell+"::"+CurrentCell+dragging;
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章