自己封装一个弹框插件

弹出层提示信息,这是移动前端开发中最常见的需求,你可能会想到一些流行的弹框插件,比如 经典的artDialog 炫酷的Sweetalert等等..

但是慢慢地你其实会发现通常情况下需求定制化要求较高,一般的弹框插件可能只满足大部分要求,自定义花的时间还不如手动自己封装一个符合自己开发习惯的弹框组件,这样后续开发效率将大大提高。

首先整理一下思路,原生javascript其实是有实现alert()方法的,但是那个会暂时性中断程序运行,并且足以让你丑拒!那么抛开这些细细一想,其实弹框就是两个div层,一个浮在底下的蒙层(遮罩层),将所有的元素遮起来,并且最好是半透明。另一个就是弹框主体部分了,一般情况需要水平垂直居中,并且通常包含标题,主体内容需要可定制,如果是模态框通常还有确认/取消按钮。最后就是弹出、关闭的时候一些动效。

所以说完全可以自己封装一个,然后放在项目中公共js中去。能自己手写的尽量不用插件....

一些默认属性值

通过一个foreach循环,类似于传入的opts继承了defaultOpts属性,在调用弹框之前执行的before()方法,相当于一些准备工作

var defaultOpts = {
                title: ‘‘,//标题
                content: ‘‘,//内容  文字 || html
                height: 50,//默认屏幕(父级)的50%
                width: 80,//默认屏幕(父级)的80%
                type: ‘alert-default‘,//弹框类型
                effect: ‘fadeIn‘,//出现效果,默认下跌落
                delayTime: 500,//效果延时时间,默认.5s
                autoClose: false,//自动关闭
                autoTime: 2000, //自动关闭时间默认2s
                autoEffect: ‘default‘,//关闭效果
                ok: ‘确定‘,
                okCallback: function(){},//确定回调
                cancel: ‘取消‘,
                cancelCallback: function(){},//取消回调
                before : function() {
                    console.log(‘before‘)
                },
                close: function() {
                    console.log(‘close‘)
                },
                blankclose: false//空白处点击关闭
            }

        for (i in defaultOpts) {
            if (opts[i] === undefined) {
                opts[i] = defaultOpts[i]
            }
        }    opts.before && opts.before()

dom结构

定义一个数组对象,里面放弹框的dom元素,alert-mask为全屏的遮罩层,alert-content为弹框的主要内容区,最后通过.join(‘’)函数将数组转换为html ,再用jquery的append()方法追加在body节点最后。

var alertHtml = [
                ‘<section class="alert-main" id="alertMain">‘,
                    ‘<div class="alert-mask li-opacity" id="alertMask"></div>‘,
                    ‘<div class="alert-content ‘+ opts.type +‘" id="alertContent">‘,
                    opts.content +‘</div>‘,
                ‘</section>‘
            ]

        $(‘body‘).append(alertHtml.join(‘‘))

设置高宽了,水平垂直居中

我这里是采用fixed定位,然后height是传进来的高(百分比),top距离屏幕顶端距离百分比为 100-传进来的高 /2 ,这样就实现了垂直居中,同理宽度也一样。这种水平垂直居中的办法也是自己长期实践总结出来自己认为最简单最实用的,兼容各种屏幕大小,当然还有很多方法,可以自行尝试

var $alertContent = $(‘#alertContent‘),
            $alertMain = $(‘#alertMain‘);

        $alertContent.css({
            ‘height‘: opts.height + ‘%‘,
            ‘top‘: (100 - opts.height)/2 + ‘%‘,
            ‘width‘: opts.width + ‘%‘,
            ‘left‘: (100 - opts.width)/2 + ‘%‘
        })

        $(‘.li-opacity‘).css({
            ‘-webkit-animation-duration‘ : opts.delayTime/1000 + ‘s‘
        })

最后一句是给遮罩层赋一个动画执行时间,实现淡入效果。详情见下面的CSS @-webkit-keyframes opacity

弹框效果

我这里实现了四个效果,分别是fadeIn跌落,sideLeft从左侧飞入,scale放大,info提示信息。可以看到,我是定义了一个集合对象,分别放置了对应的css属性,然后通过两个setTimeout函数统一赋值

var effect = {
            ‘fadeIn‘: ‘top‘,
            ‘fadeInStart‘: ‘-100%‘,
            ‘fadeInValue‘: (100 - opts.height)/2 + ‘%‘,
            ‘sideLeft‘: ‘left‘,
            ‘sideLeftStart‘: ‘-100%‘,
            ‘sideLeftValue‘: (100 - opts.width)/2 + ‘%‘,
            ‘scale‘: ‘-webkit-transform‘,
            ‘scaleStart‘: ‘scale(0)‘,
            ‘scaleValue‘: ‘scale(1)‘,
            ‘info‘: ‘-webkit-transform‘,
            ‘infoStart‘: ‘scale(1.2)‘,
            ‘infoValue‘: ‘scale(1)‘
        }

        setTimeout(function(){
            $alertContent.css(effect[opts.effect],effect[opts.effect + ‘Start‘]).addClass(‘alert-show‘)

            setTimeout(function(){
                $alertContent.css(effect[opts.effect], effect[opts.effect + ‘Value‘])
                opts.close && opts.close()
            },10)
        },opts.delayTime)

空白处点击关闭

通常情况下的需求,都会是要点击弹框空白处关闭弹框,一个点击事件搞定,重点是前面的选择器,jquery给了我们太多方便.... 当然最后为了防止点击到页面其他元素,阻止事件冒泡,组件默认行为..

if(opts.blankclose) {
            $(‘.alert-main :not(.alert-content)‘).on(‘click‘,function(event){
                $alertMain.remove()
                opts.close && opts.close()
                event.stopPropagation()
                event.preventDefault()
            })
        }

自动关闭

当autoClose为true,并且autoTime大于零时,用一个延时事件自动关闭弹框

if(opts.autoClose && opts.autoTime > 0) {
            setTimeout(function(){$alertMain.remove()},opts.autoTime)
            opts.close && opts.close()
        }

演示:

css

@-webkit-keyframes opacity {
            0% {
                opacity: 0; /*初始状态 透明度为0*/
            }
            50% {
                opacity: 0; /*中间状态 透明度为0*/
            }
            100% {
                opacity: 1; /*结尾状态 透明度为1*/
            }
        }

        .li-opacity {
            -webkit-animation-name: opacity; /*动画名称*/
            -webkit-animation-iteration-count: 1; /*动画次数*/
            -webkit-animation-delay: 0s; /*延迟时间*/
        }
        .alert-mask {
            position: fixed;
            height: 100%;
            width: 100%;
            left: 0%;
            top: 0%;
            z-index: 9998;
            background-color: rgba(0,0,0,.7);
        }
        .alert-content {
            position: fixed;
            box-sizing: border-box;
            border-radius: 4px;
            z-index: 9999;
            -webkit-transition: .4s;
            -moz-transition: .4s;
            transition: .4s;
            display: none;
        }
        .alert-show {
            display: block;
        }
        .alert-default {
            background-color: white;
        }

html

<p class="alert" data-flag="fadeIn">fadeIn</p>
   <p class="alert" data-flag="sideLeft">sideLeft</p>
   <p class="alert" data-flag="scale">scale</p>
   <p class="alert" data-flag="info">info</p>

js

require.config({
    jquery:‘component/jquery/jquery-3.1.0.min‘,
    liAlert: ‘li/li-alert‘,//常用弹框组件
})

require([‘jquery‘],function($){
        require([‘liAlert‘],function(){
            $(‘.alert‘).on(‘click‘,function(event){
                $.alert({
                    content: ‘<h1 style="display:flex;justify-content:center;">我是弹框</h1>‘,
                    effect: $(event.currentTarget).attr(‘data-flag‘),
                    blankclose: true,
                    //autoClose: true
                })
            })
        })
    })

效果图

完整的代码已上传github: https://github.com/helijun/component/tree/master/alert

时间: 2024-11-03 21:44:47

自己封装一个弹框插件的相关文章

如果exclipe中Java视图中Consol跑偏了单独形成一个弹框怎么办?

问题如图: 不和其他的在同一窗体中,而且拖动也拖不进去,则是使用以下方法: 点击工具栏上的Window--->点击Reset Perspective...这样就可以解决了. 如果exclipe中Java视图中Consol跑偏了单独形成一个弹框怎么办?,布布扣,bubuko.com

自己写的基于bootstrap风格的弹框插件

自己写的一款基于bootstrap风格的弹框插件,暂时只有确认框.提示框.后续功能扩展.bug修改再更新. ;(function($){ //默认参数 var PARAMS; var DEFAULTPARAMS = { width: 500, title: '提示消息', content: '', okbtn: '确定', cancelbtn: '取消', headerBackground: 'info', vbackdrop: 'static', //默认点击遮罩不会关闭modal vkeyb

用jQuery写了一个模态框插件

用jQuery写了一个模态框插件 大家觉得下面的框框好看么, 水印可以去掉(这个任务交给你们了(- o -)~zZ); "info"框 $("div").confrimModal("<font color=\"green\">成功! </font>", {type:"info", themeColor: "#008B8B"}, true); "alert

做一个弹框玩玩,顺便熟悉最近新学习的插件封装技术

先上图,没图不成席 [原因]由于公司从开发到现在时间都比较紧张,很多时候需要弹框的地方都直接用alert().confirm().prompt()这些自带的提示框,最大的问题是这三个哥们随着浏览器的不同进行变色,简直是前端变色龙,神奇又无奈 所以,这次和我们的帅气设计师合作总结出这三种提示框,我也通过最近的学习把新学到手的封装技术,融入了进去,相对于大神级别的人,看看就行,顺便指点一下就更好了 [目前自己思考的问题]到目前为止,自己工作也有2.5年了,早早过了只知道实现需求的时候了,更多的是培养

vue+elementui 新增和编辑如何实现公用一个弹框

//html代码: //按钮 <el-button type="primary" size="medium" @click="addEquipment">新增</el-button> <el-button type="text" size="medium" @click="handelEdit(scope.$index, scope.row)">编辑&

如何判断一个弹框是打开还是关闭状态?

1.给弹框设置标记物. <input type="hidden" id="allcomplaintlist_status" value="0"> 将value设置为0: 2:当弹框打开时,将value设置为1: $("#allcomplaintlist_status").val('1'); 3.当弹框关闭时,将value设置为0: $("#allcomplaintlist_status").va

SweetAler弹框插件与分页器插件

目录 SweetAlert插件 自定义分页器 使用Django向数据库批量插入数据 自定义分页器的思路 自定义分页器组件 SweetAlert插件 sweetalert是一款基于Bootstrap的专门用来设计弹窗的插件,具体弹窗样式及相关的代码可以参考此链接插件下载地址 打开下载好的插件之后我们需要将dist文件夹导入到我们项目的静态文件中 在html文件中导入插件 {% load static %} <script src="{% static 'jquery/jquery.min.j

自己写的jquery 弹框插件

html部分 <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <script src="jquery/jquery-1.8.2.min.js"></script> <script src="jquery/yuanBox.min.js"></script>

用jQuery写了一个模态框插件感觉挺好看的在博客园分享一下!

大家觉得下面的框框好看么, 水印可以去掉(这个任务交给你们了(- o -)~zZ); "info"框 $("div").confrimModal("<font color=\"green\">成功! </font>", {type:"info", themeColor: "#008B8B"}, true); "alert"框 $("d