下面小編就為大家?guī)硪黄狫S彈出層遮罩,隱藏背景頁面滾動條細(xì)節(jié)優(yōu)化分析。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考
一、去除滾動條方法
給body添加overflow:hidden屬性即可,IE6、7下不會生效,需要給html增加overflow:hidden屬性
樣式中需要對IE6、7及其它瀏覽器用hack辨別,這是因?yàn)楫?dāng)頁面拉到下面時(shí)如果html或body被overflow:hidden,透明彈層下面的頁面就會被部分正常隱藏,通過透明看到的一片的灰度,具體顏色跟平臺及用戶設(shè)置背景色有關(guān)。
body或html去掉滾動條后,頁面會有一個(gè)滾動條寬度/2的跳動!這個(gè)跳動對用戶體驗(yàn)來十分不好,因此給body添加一下右padding,大小為滾動條的寬度。windows平臺下滾動條的寬度為17px,linux平臺下不同滾動器滾動條寬度不一致,可以用相關(guān)代碼計(jì)算出滾動條的寬度,以下以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)滾輪滾動頁面確實(shí)不會動了,以為這就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)容了,希望能給大家一個(gè)參考