ホームページ > ウェブフロントエンド > jsチュートリアル > JS_javascript スキルを使用してズーム、ドラッグ、閉じ、最小化できるフローティング ウィンドウの完全な例

JS_javascript スキルを使用してズーム、ドラッグ、閉じ、最小化できるフローティング ウィンドウの完全な例

WBOY
リリース: 2016-05-16 16:11:09
オリジナル
1691 人が閲覧しました

この記事の例では、ズーム、ドラッグ、閉じ、最小化できるフローティング ウィンドウを実装する JS メソッドについて説明します。皆さんの参考に共有してください。具体的な実装方法は以下の通りです。

コードをコピー コードは次のとおりです:


<頭>

JS は、解放、動作、关闭および最小化された浮動口


<スクリプト言語="javascript">
var zindex=0 //全局变量
functionragClass(名前,タイトル,内容,左,上,幅,高さ){
var isMouseDown=false;
var minimum=false;
var offX=0;   //設置抓取点X坐标
変数オフY=0;   //設置抓取点Y坐标
var oldLeft;  //正常状態を保存するX座標
var oldTop;   //正常状態を保存するY座標
this.mousedown= function (){ //按下拖アニメーション点
     Bar.setCapture(); //設置抓取
     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 (){ //拖动窗口
     if (isMouseDown && !maximum){
  Bar.style.cursor='移動'
  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 (){ //松开按钮
     Bar.releaseCapture();     //取消抓取
     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 (){ //双击最大最小化
     if (!maximum){
    oldLeft=Window.style.left;   //正常状態を保存するX座標
    oldTop=Window.style.top;    //正常状態を保存するY座標
    Window.style.left='0px';
    Window.style.top='0px';
    Window.style.width= document.body.clientWidth;    //网页可见領域宽
    Title.style.width=(document.body.clientWidth-40) 'px';  //設置标题長度
    ReSize.style.display='none';
    if(Change.innerText=='-'){
      Window.style.height='100%';
      Content.style.height=document.body.clientHeight-20; //网页可见領域宽-标题高
    }その他{
      Window.style.height='20px';
    }
    最大 = true;
     }その他{
    Window.style.left=oldLeft;
    Window.style.top=oldTop;
    Window.style.width=幅 'px';
    Title.style.width=(width-40) 'px';
    ReSize.style.display='';
    if(Change.innerText=='-'){
      Window.style.height=高さ 'px';
      Content.style.height=parseInt(height-20) 'px';
    }その他{
      Window.style.height='20px';
    }
    最大=false;
     }
 if(Window.style.zIndex<=zindex){
  zindex ;
  Window.style.zIndex=zindex;
 }
}
this.changeWindow=function (){ //收缩窗口
     event.cancelBubble=true;
  if(Change.innerText=='-'){
    Window.style.height='20px';
    Change.innerText='□';
    Content.style.display='none';
    ReSize.style.display='none';
     }その他{
    if (最大値){
      Window.style.height='100%';
      Content.style.display='';
      ReSize.style.display='';
      Content.style.height=document.body.clientHeight-20; //网页可见領域宽-标题高
    }その他{
      Window.style.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" 名;
Window.className="divWindow";
Window.style.left=left 'px';
Window.style.top=top 'px';
Window.style.width=幅 'px';
Window.style.height=高さ 'px';
Window.onclick=function(){
if(parseInt(Window.style.zIndex)<=zindex){
zindex ;
Window.style.zIndex=zindex;
}
}
this.Window=ウィンドウ;
//パブリック属性はクラス外で操作できます。クラス外で操作したい場合は、要素をパブリック属性に変更できます

var Bar=document.createElement("div");
Bar.id="divBar" 名前;
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" 名前;
Title.className="divTitle";
Title.style.width=(width-40) 'px' // 適応可能なタイトルの長さ
Title.innerText=title;
Bar.appendChild(タイトル);
var Change=document.createElement("span");
Change.id="divChange" 名;
Change.className="divChange";
Change.innerText="-";
Change.ondblclick=this.changeWindow;
Change.onclick=this.changeWindow;
Bar.appendChild(Change);
var Close=document.createElement("span");
Close.id="divClose" 名前;
Close.onclick=function(){
Window.style.display='none';
}
Close.className="divClose";
Close.innerText="×";
Bar.appendChild(Close);
var Content=document.createElement("div");
Content.id="divContent" 名;
Content.className="divContent"
Content.innerHTML=コンテンツ;
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){ //最小幅を設定します
Window.style.width=幅 'px';
Title.style.width=(width-40) 'px';
}
If(height>100){ //最小の高さを設定します
Window.style.height=高さ 'px';
Content.style.height=parseInt(height-20) 'px';
}
}
}
ReSize.onmouseup=function(){
ReSize.releaseCapture();
isMouseDown=false;
}
Window.appendChild(ReSize);
var Iframe=document.createElement("iframe"); // IFRAME を追加し、IE6.0 で

この記事が皆様の JavaScript プログラミング設計に役立つことを願っています。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート