jQuery點擊按鈕彈出遮罩層且內(nèi)容居中特效
本文為大家分享了jQuery點擊按鈕彈出遮罩層且內(nèi)容居中的特效,下面來看最終實現(xiàn)的效果:
由于是測試的程序,所以我未加關(guān)閉的按鈕。
一、主體程序
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>彈出居中遮罩</title> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <link rel="stylesheet" type="text/css" href="css/layout.css"/> </head> <body> <section class="test"> 這里是主體內(nèi)容<br /> <input type="button" class="testButton" value="彈出遮罩" /> </section> <section class="testBg"> <section class="testCont"> 這里是彈出的內(nèi)容測試 </section> </section> <script src="js/jquery-1.11.0.js" type="text/javascript" charset="utf-8"></script> <script src="js/layout.js" type="text/javascript" charset="utf-8"></script> </body> </html>
二、CSS樣式
*{ margin: 0; padding: 0; } .testBg{ position: absolute; top: 0; background-color: #000; filter:alpha(opacity=80); /* IE */ -moz-opacity:0.8; /* Moz + FF */ opacity: 0.8; /* 支持CSS3的瀏覽器(FF 1.5也支持)*/ display:none ; } .testBg .testCont{ position: absolute; top: 0; left: 0; width:200px; border: 1px #ffc700 solid; color: #ffc700; }
三、JS程序
這個才是本次隨筆所說的重點,下面來看一段錯誤的JS程序:
$(function(){ $(".testBg").height($(window).height()).width($(window).width()); //使遮罩的背景覆蓋整個頁面 var testContTop=($(window).height()-$(".testCont").height())/2; //計算彈出的框距離頁面頂部的距離 var testContWidth=($(window).width()-$(".testCont").width())/2; //計算彈出的框距離頁面左邊的距離 $(".testCont").css({ "top":testContTop, "left":testContWidth }); $(".testButton").click(function(){ $(".testBg").show(); }) })
上面這段程序看起來沒有問題,那么來看一下輸出的結(jié)果:
實際測量的時候上下的間距是不一致的。
那么正確的JS程序是:
$(function(){ $(".testBg").height($(window).height()).width($(window).width());//使遮罩的背景覆蓋整個頁面 $(".testButton").click(function(){ $(".testBg").show(); showDiv(); }) }) function showDiv(){ var testContTop=($(window).height()-$(".testCont").height())/2; //計算彈出的框距離頁面頂部的距離 var testContWidth=($(window).width()-$(".testCont").width())/2; //計算彈出的框距離頁面左邊的距離 $(".testCont").css({ "top":testContTop, "left":testContWidth }); }
從上面程序可以看出在遮罩層彈出顯示以后再執(zhí)行一個函數(shù)動態(tài)的設(shè)置彈出層的背景大小和距離頁面的上間距和左間距,而不是一開始加載JS時就已經(jīng)設(shè)置好彈出層各項參數(shù)。
以上就是本文的全部內(nèi)容,教大家如何實現(xiàn)點擊按鈕彈出遮罩層且內(nèi)容居中的效果,
相關(guān)文章
Jquery Post處理后不進入回調(diào)的原因及解決方法
通過Jquery的Post方法把Json數(shù)據(jù)傳到Jsp后臺,處理后卻怎么都不進入回調(diào)函數(shù),解決方法如下2014-07-07jQuery獲取父節(jié)點、子節(jié)點、兄弟節(jié)點的代碼
這篇文章主要介紹了jQuery獲取父節(jié)點、子節(jié)點、兄弟節(jié)點的代碼,需要的朋友可以參考下2023-06-06jquery上傳插件fineuploader上傳文件使用方法(jquery圖片上傳插件)
這篇文章主要介紹了jquery插件fineuploader上傳文件很用方法2013-12-12快速解決jquery.touchSwipe左右滑動和垂直滾動條沖突
這篇文章主要介紹了快速解決jquery.touchSwipe左右滑動和垂直滾動條沖突問題,感興趣的小伙伴們可以參考一下2016-04-04