JS彈出層遮罩,隱藏背景頁面滾動條細節(jié)優(yōu)化分析
一、去除滾動條方法
給body添加overflow:hidden屬性即可,IE6、7下不會生效,需要給html增加overflow:hidden屬性
樣式中需要對IE6、7及其它瀏覽器用hack辨別,這是因為當頁面拉到下面時如果html或body被overflow:hidden,透明彈層下面的頁面就會被部分正常隱藏,通過透明看到的一片的灰度,具體顏色跟平臺及用戶設置背景色有關。
body或html去掉滾動條后,頁面會有一個滾動條寬度/2的跳動!這個跳動對用戶體驗來十分不好,因此給body添加一下右padding,大小為滾動條的寬度。windows平臺下滾動條的寬度為17px,linux平臺下不同滾動器滾動條寬度不一致,可以用相關代碼計算出滾動條的寬度,以下以windows平臺為例。
相關代碼:
document.documentElement.style.cssText = ‘overflow:none;+overflow:hidden;_overflow:hidden;'; document.body.style.cssText = ‘overflow:hidden;+overflow:none;_overflow:none;padding:0 17px 0 0;';
以上代碼不考慮html或body是否有內聯(lián)樣式 ,如果html或body有內聯(lián)樣式則需要累加,否則會清空原有樣式。
二、去除隱患其它方法滾動頁面(防止誤操作)
隱藏滾動條后,用鼠標滾輪滾動頁面確實不會動了,以為這就ok了,不是…
鍵盤快捷鍵也可以操作瀏覽器的一些操作,與滾動頁面相關的,比如:上下按鍵、翻頁按鍵等。針對鍵盤快捷鍵,需要取消他們的默認操作。
三、添加彈出層樣式
給body添加全局樣式(兼容IE6)
height:100%;
給彈層添加滾動樣式
overflow-y: auto; width: 100%; height: 100%; left:0; _padding:0 17px 0 0; //IE6bug,子元素絕對定位后對于父元素的padding依然有效
以上這篇JS彈出層遮罩,隱藏背景頁面滾動條細節(jié)優(yōu)化分析就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
HTML中setCapture、releaseCapture 使用方法淺析
本文給大家簡單介紹了下html中的高級拖動技術setCapture、releaseCapture的使用方法,有需要的小伙伴可以參考下2016-09-09JavaScript實現(xiàn)監(jiān)控上傳和下載進度
這篇文章主要介紹了JavaScript實現(xiàn)監(jiān)控上傳和下載進度,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值需要的小伙伴可以參考一下2022-05-05Bootstrap標簽頁(Tab)插件切換echarts不顯示問題的解決
這篇文章主要給大家介紹了關于Bootstrap標簽頁(Tab)插件切換echarts不顯示問題的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-07-07js中net::ERR_FILE_NOT_FOUND報錯的解決
本文主要介紹了js中net::ERR_FILE_NOT_FOUND報錯的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07JavaScript hasOwnProperty() 函數實例詳解
hasOwnProperty()函數用于指示一個對象自身(不包括原型鏈)是否具有指定名稱的屬性。下面通過本文給大家分享JavaScript hasOwnProperty() 函數實例講解,感興趣的朋友一起看看吧2017-08-08