使用Javascript做弹出框的具体步骤

maiziedu · 2016-02-19 03:32:27 · 2861 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2016-02-19 03:32:27 的主题,其中的信息可能已经有所发展或是发生改变。

在学习JavaScript的过程中,有些童鞋可能会对如何用JavaScript实现弹出框存在各种各样的疑问,今天小编就和大家分享一个在一个web前端培训网站上看到的一篇关于弹出框的干货文章给还在JavaScript魂斗路上中的小伙伴们。

弹出框在页面中是不可缺少的一部分,我们今天来实现简单的弹出框效果。

图片1.png

首先我们来分析弹出框的部件。简单弹出框分为头、内容、尾部。 头部中有标题和关闭按钮,内容就可以图文、媒体、iframe、flash等等,尾部就是按钮(确认,取消等等),这个例子尾部我就不加入按钮了,这个例子主要是实现弹出框的核心部分。

<!DOCTYPE html>

消息

X
弹出框已显示

弹出框,在头部按下的时候,开启移动模式,在头部松开的时候就禁止移动。其实就这么一句的意思,当然逻辑也是比较简单的。

这里我们就可能想到了几个变量,移动的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以前的版本)。

图片2.png

以上就是使用JavaScript实现弹出框的方式方法,希望对大家学习有所帮助吧。最后强烈建议大家按照上述介绍,自己实现下,所谓“好记性不如烂笔头”,看了懂了,如果没有实操的话,很难内化成自己的东西。

相关阅读文章:《web前端入门,导航栏右侧放什么按钮合适?》http://www.maiziedu.com/group/article/13645/

文章来源:原作者 :towaywu的blog


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2861 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传