亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

js自定義彈框插件的封裝

2019-11-19 16:05:08
字體:
來源:轉載
供稿:網友

彈出層提示信息,這是移動前端開發中最常見的需求,你可能會想到一些流行的彈框插件,比如 經典的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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美视频国产精品| 青青草99啪国产免费| 久久久免费av| 国产成人极品视频| 亚洲在线免费视频| 日韩视频免费观看| 狠狠久久五月精品中文字幕| 亚洲激情视频网站| 欧美激情在线有限公司| 欧美性受xxx| 国产精品久久久久久久久久99| 色偷偷综合社区| 91国内产香蕉| 亚洲成人在线视频播放| 日韩在线视频中文字幕| 日韩av在线免费观看| 国产精品久久久久免费a∨大胸| 亚洲图片欧洲图片av| 精品国产自在精品国产浪潮| 日韩视频在线免费观看| 亚洲黄色有码视频| 色综合伊人色综合网站| 91免费在线视频| 日韩免费在线免费观看| 欧美老女人xx| 亚洲欧美成人网| 亚洲一区av在线播放| 欧美性猛交xxxx偷拍洗澡| 成人国产精品一区| 久久久久免费视频| 亚洲精品456在线播放狼人| 91精品啪在线观看麻豆免费| 国产精品中文在线| 亚洲国产精品va在线看黑人动漫| 日本久久久a级免费| www日韩中文字幕在线看| 亚洲第一在线视频| 亚洲人成电影在线播放| 亚洲精品美女久久久| 欧美剧在线观看| 亚洲电影免费观看高清完整版在线| 国产91精品网站| 国产91在线播放| 久久久久成人精品| 97免费中文视频在线观看| 精品高清一区二区三区| 亚洲网站在线播放| 亚洲精品一区二三区不卡| 91色视频在线导航| 亚洲人成电影网站色| 亚洲成人精品久久| 96精品视频在线| 青草青草久热精品视频在线观看| 亚洲综合在线播放| 欧美视频在线观看免费| 2019国产精品自在线拍国产不卡| 欧美久久精品一级黑人c片| 一本色道久久88综合日韩精品| 成人欧美一区二区三区黑人| 久久久久久网站| 亚洲欧美日韩在线一区| 在线日韩第一页| 国产精品久久久久av免费| 精品日韩中文字幕| 一区二区三区日韩在线| 欧美小视频在线观看| 日本sm极度另类视频| 国产精品久久久久国产a级| 欧美日韩国内自拍| 久久黄色av网站| 日韩精品在线观| 亚洲女人初尝黑人巨大| 欧美性猛交xxxx乱大交3| 国产精品免费观看在线| 亚洲欧洲激情在线| 亚洲一区二区三区毛片| 伊人av综合网| 日韩专区在线观看| 97精品一区二区视频在线观看| 成人黄色av播放免费| 91精品在线看| 国产激情视频一区| 性视频1819p久久| 影音先锋欧美精品| 一色桃子一区二区| 国产精品欧美风情| 欧美日韩中国免费专区在线看| 成人国产精品久久久久久亚洲| 亚洲精品丝袜日韩| 国产精品自拍视频| 性色av一区二区咪爱| 亚洲一区二区三区sesese| 欧美一级淫片aaaaaaa视频| 久久99亚洲热视| 欧美午夜宅男影院在线观看| 日本国产一区二区三区| 亚洲综合在线做性| 日韩美女在线观看一区| 色综合老司机第九色激情| 深夜福利91大全| 尤物精品国产第一福利三区| 欧美香蕉大胸在线视频观看| 亚洲激情视频在线| 国产亚洲免费的视频看| 久久理论片午夜琪琪电影网| 国产美女精彩久久| 亚洲欧美日韩国产中文专区| 97久久精品视频| 久久国产精品首页| 欧美一区深夜视频| 亚洲精品国精品久久99热一| 久久久精品久久久| 国产精品高潮呻吟久久av野狼| 亚洲欧美色图片| 亚洲一区二区三区sesese| 亚洲第一天堂av| 亚洲人成网站在线播| 中文字幕在线精品| 日韩av片免费在线观看| 久久免费视频网| 亚洲精品久久在线| 91国产中文字幕| 久久久精品国产| 91久久在线播放| 91av成人在线| 精品久久久久久中文字幕一区奶水| 日本久久久久久久久久久| 亚洲欧美日韩精品久久亚洲区| 91在线看www| 久久人人爽人人爽爽久久| 国产91在线播放| 韩国视频理论视频久久| 91免费精品视频| 欧美激情在线一区| 国产日韩一区在线| 日本一区二区三区在线播放| 久久青草福利网站| 日韩中文字幕亚洲| 中文字幕欧美亚洲| 国内免费精品永久在线视频| 欧美在线免费视频| 91极品女神在线| 欧美第一黄网免费网站| 亚洲日本成人女熟在线观看| 欧美日韩国产精品一区二区三区四区| www.亚洲成人| 国产精品成人观看视频国产奇米| 91精品国产色综合久久不卡98口| 668精品在线视频| 在线播放亚洲激情| 亚洲xxxx妇黄裸体| 国产精品视频久| 欧美国产日韩一区二区在线观看| 亚洲综合第一页| 国产一区二区三区三区在线观看| 久久久久一本一区二区青青蜜月| 俺也去精品视频在线观看| 91精品国产高清自在线看超| 日韩亚洲欧美成人| 久久天堂电影网| 亚洲毛片在线免费观看| 91沈先生在线观看| 国产深夜精品福利| 亚洲国产成人久久综合|