JS implements a full instance of a floating window that can be scaled dragged closed and minimized

  • 2020-05-10 17:43:22
  • OfStack

The example in this article shows how JS implements a zooming, dragging, closing, and minimizing floating window method. Share with you for your reference. The specific implementation method is as follows:

<!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=utf-8" />
<title>JS Realize zooming, dragging, closing and minimizing the floating window </title>
</head>
<style type="text/css">
 .divWindow{word-wrap:break-word;position:absolute; overflow:hidden;}
 .divBar{border:#000000 1px solid;position:absolute;border-bottom:#000000 1px solid;width:100%;height:20px;background-color:#0099FF;cursor:hand;line-height:20px;}
 .divChange{position:absolute;right:25px;font-size:10pt;}
 .divClose{position:absolute;right:5px;font-size:11pt;}
 .divTitle{position:absolute;left:5px;font-size:10pt;white-space:nowrap;text-overflow:ellipsis;-o-text-overflow:ellipsis;overflow: hidden;}
 .divContent{border:#000000 1px solid;border-top:#000000 0px solid;position:absolute; top:20px;width:100%; background-color:#FFFFFF; overflow-y:auto;
    SCROLLBAR-BASE-COLOR: #FFFFFF;SCROLLBAR-ARROW-COLOR: #999999;SCROLLBAR-FACE-COLOR: #EEEEEE;SCROLLBAR-HIGHLIGHT-COLOR: #EEEEEE;
    SCROLLBAR-SHADOW-COLOR: #EEEEEE;SCROLLBAR-3DLIGHT-COLOR: #FFFFFF;SCROLLBAR-TRACK-COLOR: #FFFFFF;SCROLLBAR-DARKSHADOW-COLOR: #CCCCCC;}
 .divReSize{height:7px; width:7px; overflow:hidden; background-color:#0000FF; position:absolute; bottom:6px; right:6px; cursor:nw-resize}
 .divIframe{height:100%;width:100%;}
</style>
<script language="javascript">
var zindex=0  // The global variable
function dragClass(name,title,content,left,top,width,height){
var isMouseDown=false;
var maximum=false;
var offX=0;   // Set grab point X coordinates
var offY=0;   // Set grab point Y coordinates
var oldLeft;  // In the normal state X coordinates
var oldTop;   // In the normal state Y coordinates
this.mousedown= function (){    // I'm going to hit the drag point
     Bar.setCapture(); // Set the grab
     offX=parseInt(event.clientX)-parseInt(Window.style.left);
     offY=parseInt(event.clientY)-parseInt(Window.style.top);
     isMouseDown=true;
 if(Window.style.zIndex<=zindex){
  zindex++;
  Window.style.zIndex=zindex;
 }
}
this.mousemove= function (){    // Drag the window
     if (isMouseDown && !maximum){
  Bar.style.cursor='move'
  Window.style.left=event.clientX-offX;
  Window.style.top=event.clientY-offY;
  if(Window.style.zIndex<=zindex){
   zindex++;
   Window.style.zIndex=zindex;
  }
     }
}
this.mouseup=function (){     // Loosen the button
     Bar.releaseCapture();     // Cancel the grab
     Bar.style.cursor='hand';
     if (parseInt(Window.style.top)<0){
     Window.style.top='0px';
     }
     if (parseInt(Window.style.left)<0){
     Window.style.left='0px';
     }
     isMouseDown=false;
}
this.dblclick=function (){    // Double click maximum minimization
     if (!maximum){
    oldLeft=Window.style.left;   // In the normal state X coordinates
    oldTop=Window.style.top;    // In the normal state Y coordinates
    Window.style.left='0px';
    Window.style.top='0px';
    Window.style.width= document.body.clientWidth;    // The web page has a wide viewable area
    Title.style.width=(document.body.clientWidth-40)+'px';  // Set the header length
    ReSize.style.display='none';
    if(Change.innerText==' - '){
      Window.style.height='100%';
      Content.style.height=document.body.clientHeight-20; // The web page has a wide viewable area - Height of the title
    }else{
      Window.style.height='20px';
    }
    maximum=true;
     }else{
    Window.style.left=oldLeft;
    Window.style.top=oldTop;
    Window.style.width=width+'px';
    Title.style.width=(width-40)+'px';
    ReSize.style.display='';
    if(Change.innerText==' - '){
      Window.style.height=height+'px';
      Content.style.height=parseInt(height-20)+'px';
    }else{
      Window.style.height='20px';
    }
    maximum=false;
     }
 if(Window.style.zIndex<=zindex){
  zindex++;
  Window.style.zIndex=zindex;
 }
}
this.changeWindow=function (){   // Contraction of the window
     event.cancelBubble=true;
  if(Change.innerText==' - '){
    Window.style.height='20px';
    Change.innerText=' - ';
    Content.style.display='none';
    ReSize.style.display='none';
     }else{
    if (maximum){
      Window.style.height='100%';
      Content.style.display='';
      ReSize.style.display='';
      Content.style.height=document.body.clientHeight-20; // The web page has a wide viewable area - Height of the title
    }else{
      Window.style.height=height+'px';
      Content.style.display='';
      ReSize.style.display='';
      Content.style.height=parseInt(height-20)+'px';
    }
    Change.innerText=' - ';
     }
} var Window=document.createElement("div");
 Window.id="divWindow"+ name;
 Window.className="divWindow";
 Window.style.left=left+'px';
 Window.style.top=top+'px';
 Window.style.width=width+'px';
 Window.style.height=height+'px';
 Window.onclick=function(){
  if(parseInt(Window.style.zIndex)<=zindex){
   zindex++;
   Window.style.zIndex=zindex;
  }
 }
this.Window=Window;
// Public property, can be operated outside the class; To operate outside the class, change the element to a public attribute
 
var Bar=document.createElement("div");
 Bar.id="divBar"+name;
 Bar.onselectstart="return false";
 Bar.className="divBar";
 Bar.onmousedown=this.mousedown;
 Bar.ondblclick=this.dblclick;
 Bar.onmousemove=this.mousemove;
 Bar.onmouseup=this.mouseup;
 Window.appendChild(Bar);
var Title=document.createElement("span");
 Title.id="divTitle"+ name;
 Title.className="divTitle";
 Title.style.width=(width-40)+'px';    // Adaptive header length
 Title.innerText=title;
 Bar.appendChild(Title);
var Change=document.createElement("span");
 Change.id="divChange"+ name;
 Change.className="divChange";
 Change.innerText=" - ";
 Change.ondblclick=this.changeWindow;
 Change.onclick=this.changeWindow;
 Bar.appendChild(Change);
var Close=document.createElement("span");
 Close.id="divClose"+ name;
 Close.onclick=function(){
  Window.style.display='none';
 }
 Close.className="divClose";
 Close.innerText=" x ";
 Bar.appendChild(Close);
var Content=document.createElement("div");
 Content.id="divContent"+ name;
 Content.className="divContent"
 Content.innerHTML=content;
 Content.style.height=parseInt(height-20)+'px';
 Window.appendChild(Content);
 
var ReSize=document.createElement("div");
 ReSize.className="divReSize";
 ReSize.onmousedown=function(){
  if(Window.style.zIndex<=zindex){
   zindex++;
   Window.style.zIndex=zindex;
  }
  ReSize.setCapture();
  isMouseDown=true;
 }
 ReSize.onmousemove=function(){
   if (isMouseDown && !maximum)
   {
   width=parseInt(event.clientX)-parseInt(Window.style.left)+5;
   height=parseInt(event.clientY)-parseInt(Window.style.top)+5;
   if(width>100){       // Set minimum width
    Window.style.width=width+'px';
    Title.style.width=(width-40)+'px';
   }
   if(height>100){       // Set minimum height
    Window.style.height=height+'px';
    Content.style.height=parseInt(height-20)+'px';
   }
   }
 }
 ReSize.onmouseup=function(){
  ReSize.releaseCapture();
  isMouseDown=false;
 }
 Window.appendChild(ReSize);
var Iframe=document.createElement("iframe"); // add iframe . IE6.0 Under the shade <select> controls
 Iframe.className="divIframe";
 Window.appendChild(Iframe);
 
 document.body.appendChild(Window); }
</script>
<body>
<script>
//dragClass(ID, The window title , content ,X coordinates ,Y coordinates , wide , long )
var c1=" window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1 window 1";
objWin1=new dragClass('win1',' Drag the window 1',c1,0,150,300,300);
var c2=" window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2 window 2";
objWin2=new dragClass('win2',' Drag the window 2',c2,350,150,300,300);
var objWin3;
function openWin(){
 if(objWin3==null){
  var c3="123 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3 window 3";
  objWin3=new dragClass('win3',c3,c3,700,150,300,300);
 }else{
    if(objWin3.Window.style.display=='none'){
   objWin3.Window.style.display='';
    }
 }
}
</script>
<input type="button" value=" Pop up [window] 3 】 " onClick="openWin()" />
</body>
</html>

I hope this article has been helpful to your javascript programming.


Related articles: