JAVASCRIPT實現彈出框

pdeb4564 8年前發布 | 14K 次閱讀 HTML JavaScript開發 JavaScript

來自: http://www.wutongwei.com/front/infor_showone.tweb?id=205

Javascript實現彈出框

作者 :towaywu

<p>  2016-02-19 08:57:50.0 </p>

<p>  22 瀏覽 </p>

<p>  類別 :編程語言 <a href="/misc/goto?guid=4959666155918942416" rel="nofollow,noindex" target="_blank">HTML/CSS/JAVASCRIPT</a> <a href="/misc/goto?guid=4959666156021639425" rel="nofollow,noindex" target="_blank">前端編程</a> </p>

</div>

</div>

彈出框在頁面中是不可缺少的一部分. 我們今天來實現簡單的彈出框效果.

首先我們來分析彈出框的部件.簡單彈出框分為頭,內容,尾部. 頭部中有標題和關閉按鈕,內容就可以圖文,媒體,iframe,flash等等,尾部就是按鈕(確認,取消等等),這個例子尾部我就不加入按鈕了,這個例子主要是實現彈出框的核心部分.

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <style>
        body, div{
            padding: 0;
            margin: 0;
        }
        html, body {
            width: 100%;
            height: 100%;
        }
        a {
            text-decoration: none;
        }
        .pop {
            border-radius: 5px;
            background-color: #fff;
            border: #eee 1px solid;
            position: absolute;
            width: 350px;
            left: 35%;
            top: 25%;
        }
        .pop-title {
            background-image: linear-gradient(#eee,#efefef);
            position: relative;
            cursor: pointer;
        }
        .pop-title h3,.pop-title a{
            display: inline-block;
        }
        .pop-title h3{
            font-size: 14px;
            margin: 0;
            padding: 5px;
        }
        .pop-title a {
            position: absolute;
            top: 5px;
            right: 5px;
        }
        .pop-content {
            padding: 10px;
        }
    </style>
</head>
<body>
    <div>
        <div>
            <h3>消息</h3>
            <a href="javascript:;">X</a>
        </div>
        <div>
            彈出框已顯示
        </div>
        <div></div>
    </div>
</body>
</html>

彈出框,在頭部按下的時候,開啟移動模式,在頭部松開的時候就禁止移動.其實就這么一句的意思. 當然邏輯也是比較簡單的.

這里我們就可能想到了幾個變量,移動的X,Y坐標,移動的開關和禁止. 然后就是給title加入onmousedown 和 onmouseup事件.

onmousedown事件中主要是開啟移動.

onmouseup 事件中邏輯主要是關閉移動,禁止移動彈出框.

接著需要移動,而移動需要時在某個范圍內移動.這里我們是在body里面移動. 所以給body加入onmousemove事件. 這里面做的事情就是移動彈出框的位置處理.

在這三個事件中主要是配合了CSS中的position屬性和JS中的Event事件中的屬性的坐標.

  var pop = document.getElementsByClassName("pop")[0];
        var pop_title = pop.getElementsByClassName("pop-title")[0];
        var bd = document.body;
        var x = 0;
        var y = 0;
        var ismove = false; // 是否開啟移動
        var downx = 30;
        var downy = 30;
        pop_title.onmousedown = function (e) {
            x = e.pageX;
            y = e.pageY;
            downx = e.offsetX;
            downy = e.offsetY;
            ismove = true;
        }
        bd.onmousemove = function (e) {
            if (ismove) {
                var cx = e.pageX - downx;
                var cy = e.pageY - downy;
                pop.style.left = cx + "px";
                pop.style.top = cy + "px";
                x = e.x;
                y = e.y;
            }
            e.preventDefault();
        }
        pop_title.onmouseup = function (e) {
            x = e.pageX;
            y = e.pageY;
            ismove = false;
            console.log("移動完成")
        }

移動彈出框完成后,我們給關閉按鈕加入關閉事件.

//關閉       
 var pop_close = pop.getElementsByClassName("pop-close")[0];
  pop_close.onclick = function () {
      pop.parentNode.removeChild(pop);
 }

好了,簡單的彈出框就實現了.同樣代碼自己可以優化封裝,加入其它的功能.兼容性問題可能需要自己去處理一下(IE9以前的版本).

本文屬于吳統威的博客, 微信公眾號:bianchengderen,QQ群:186659233 的原創文章,轉載時請注明出處及相應鏈接:http://www.wutongwei.com/front/infor_showone.tweb?id=205 ,歡迎大家傳播與分享.

標簽 :javascript教程javascript實例

</div>

</div>

</div>

towaywu
<div> 
 <p>一個喜歡技術,走在創業路上的屌絲!歡迎一起交流</p>

 <p> 編程的人微信公眾號: <strong>bianchengderen</strong> </p>

</div>

<p> <img src="https://simg.open-open.com/show/7ec06c8bcf57762c304cbd61f6e49583.jpg" class="alignCenter" width="430" height="430" /> </p>

<strong>交流QQ群: 186659233</strong> 

</div>

</div>

</div> </div>

 本文由用戶 pdeb4564 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!