jQuery操作dom實現(xiàn)彈出頁面遮罩層(web端和移動端阻止遮罩層的滑動)
最近項目遇到了遮罩層的一些問題,總結一下:
彈出遮罩層
遮罩層彈出有非常多的方法,這里只寫出本人用的代碼,使用jq操作dom的方法進行實現(xiàn)的。
<style>.box{position:absolute;width:100%;left:50%;height:auto;z-index:100;background-color:#f5f5f5;border:1px #ddd solid;padding:1px;}</style><div id="bg" v-click="closeMask()"></div> <div class="box" style="display:none"> <input v-click="closeMask()" class="inpt_bottomb white" value="取 消" type="button" /> <div class="clear"></div> </div> </div>
#bg為透明度為0.6的一個遮罩頁面,.box為遮罩層上的按鈕。
//彈出遮罩 $("#bg").css({ display: "block", height: $(document).height() }); var $box = $('.box'); $box.css({ //設置彈出層距離左邊的位置 left: ($("body").width() - $box.width()) / 2 -5 + "px", //設置彈出層距離上面的位置 top: ($(window).height() - $box.height()) + $(window).scrollTop() + "px", display: "block" });
有了觸發(fā)遮罩的行為后,設置遮罩的高度為整個頁面高度和可見性可見,然后對按鈕出現(xiàn)的位置進行定位布局的設置,需要注意的是top屬性要加上滾輪的高度,這樣會保證我們的按鈕會一直在視線之內(nèi)。
關閉遮罩時也只需設置可見性即可。
效果圖
遇到問題
功能上是可以實現(xiàn)的,但還是有些缺陷問題,比如頁面過長時遮罩層也會隨著頁面進行滑動,按鈕的位置就會發(fā)生變化:
解決方案PC端
pc端的解決思路就是在彈出遮罩層的時候取消已經(jīng)存在的滾動條,達到無法滾動的效果。
也就是說給body添加overflow:hidden屬性即可,IE6、7下不會生效,需要給html增加overflow:hidden屬性。
解決方案移動端
移動端取消滾動條是達不到效果的,這時就需要去除遮罩層和按鈕層的touchmove的默認事件,代碼如下:
$('.box,#bg').bind("touchmove",function(e){ e.preventDefault(); });
相關文章
jquery實現(xiàn)圖片左右間隔滾動特效(可自動播放)
圖片左右間隔滾動Jquery特效,點擊滾動,不點擊自動滾動,具體處理程序如下,感興趣的朋友可以參考下哈,希望可以幫助到你2013-05-05非常實用的jQuery代碼段集錦【檢測瀏覽器、滾動、復制、淡入淡出等】
這篇文章主要介紹了非常實用的jQuery代碼段集錦,總結分析了包括jQuery檢測瀏覽器、滾動、復制、粘貼、淡入淡出等操作實現(xiàn)技巧,需要的朋友可以參考下2019-08-08jquery獲取table中的某行全部td的內(nèi)容方法
jquery獲取table中的某行全部td的內(nèi)容方法,需要的朋友可以參考一下2013-03-03js整數(shù)字符串轉換為金額類型數(shù)據(jù)(示例代碼)
本篇文章主要是對js整數(shù)字符串轉換為金額類型數(shù)據(jù)的示例代碼進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12jQuery+css實現(xiàn)炫目的動態(tài)塊漂移效果
這篇文章主要介紹了jQuery+css實現(xiàn)的動態(tài)塊漂移效果,涉及jQuery基于隨機數(shù)與時間函數(shù)動態(tài)操作頁面元素樣式的相關技巧,需要的朋友可以參考下2016-01-01