首先再次詳細(xì)解釋一下JS中窗口和網(wǎng)頁(yè)的幾種尺寸屬性的含義
document.body.clientWidth(網(wǎng)頁(yè)可見區(qū)域?qū)挘菏侵笧g覽器顯示網(wǎng)頁(yè)的區(qū)域?qū)挾龋话g覽器的邊框?qū)挾群痛怪睗L動(dòng)條的寬度。大小隨著瀏覽器的窗口大小而改變。
document.body.clientHeight(網(wǎng)頁(yè)可見區(qū)域高):是指瀏覽器顯示網(wǎng)頁(yè)的區(qū)域所能看到的高度,不包括瀏覽器的邊框?qū)挾群退綕L動(dòng)條的高度。大小隨著瀏覽器的窗口大小而改變。
document.body.scrollTop(網(wǎng)頁(yè)被卷去的高):是指拉動(dòng)垂直滾動(dòng)條時(shí)網(wǎng)頁(yè)上面被地址欄及菜單欄遮蓋著的部分的高。
document.body.scrollLeft(網(wǎng)頁(yè)被卷去的左):是指拉動(dòng)水平滾動(dòng)條時(shí)網(wǎng)頁(yè)左面被左邊線遮蓋著的部分的寬。
現(xiàn)在我們來(lái)分析一下程序該如何實(shí)現(xiàn):
第一步我們要實(shí)現(xiàn)的是使層在彈出時(shí)絕對(duì)居中不去考慮是否有滾動(dòng)條的情況。
1.計(jì)算出層距離顯示區(qū)域左邊和上邊的位置
注意:divId指的是所要居中的層,divId.clientWidth為其寬度!@
var divId = document.getElementById("xxx");
var v_left=(document.body.clientWidth-divId.clientWidth)/2;
var v_top=(document.body.clientHeight-divId.clientHeight)/2;
2.把得到的值重新賦給DIV的left和top屬性
divId.style.left=v_left;
divId.style.top=v_top;
說(shuō)明:divId為DIV標(biāo)簽的id值
這樣這個(gè)層就是居中顯示的了。
第二步我們要實(shí)現(xiàn)的是使在拖動(dòng)滾動(dòng)條的情況下彈出的層也能居中。
其實(shí)很簡(jiǎn)單我們只要把拖動(dòng)的寬度和高度加到前面計(jì)算出來(lái)的左邊距和上邊距中就OK 了。
v_left+=document.body.scrollLeft;
v_top+=document.body.scrollTop;
2.把得到的值重新賦給DIV的left和top屬性
divId.style.left=v_left;
divId.style.top=v_top;
這樣顯示出來(lái)就是居中的了。
完整代碼如下:
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注