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