通過JavaScript使Div居中并隨網頁大小改變而改變
更新時間:2013年06月24日 10:36:57 作者:
自己的頁面太難看了,要居中沒居中,要顏色沒顏色,但是無論是怎么樣都得使登錄的框居中吧,下面與大家分享下通過JavaScript可以簡單的使Div在頁面上居中,隨著網頁大小的改變做出相應的改變
在使用Java做后臺的時候,都會做到登錄的頁面,但是自己的頁面太難看了,要居中沒居中,要顏色沒顏色,但是無論是怎么樣都得使登錄的框居中吧!以前的想法是通過CSS+Div使div居中,但是現在的想法變了,通過JavaScript可以簡單的使Div在頁面上居中,隨著網頁大小的改變做出相應的改變。而且只要明白了居中的原理輕而易舉的就可以實現了。
先看一下居中的原理吧!
先看一張圖。
從圖中看到了什么?可以看到紅色的框居中了,為什么會居中呢?通過觀察可以發(fā)現紅框的上下的藍色的間距線是一樣長的,這樣可以確保了垂直居中,紅框的左右的綠色間距線也是一樣長的,這樣可以確保了水平居中。
但是怎么使上下的間距相等呢?左右的間距相等呢?
在看一張圖:
假設當前網頁的高為350px,寬為400px,而紅框的高為150px,寬為200px,我們可以發(fā)現網頁的高減去紅框元素的高得到200px像素,而這200px像素正是上下邊距的總和,上下邊距各得到了100px,同理,左右也是一樣的。
有沒有感覺到什么?
如果我們知道了網頁元素的高或寬,減去元素的高或寬,然后在除以2,就得到了上下左右邊距的距離。我們通常給元素的定位是怎么定的呢?不都是通過top和left的坐標定的嗎?那么現在紅框的坐標是什么呢?
再看一張圖:
紅色框的坐標是藍色的上線100px,和綠色的左線100px,即left和top的值,這兩個值不是算出來的嗎?
可以總結一個公式:
居中的元素的top =(網頁高 –元素的高)/ 2;
居中的元素的left= (網頁寬 –元素的寬) /2;
轉化為JavaScript的語法為:
top = (document.body.clientHeight - element.offsetHeight)/2;
left = (document.body.clientWidth - element.offsetWidth)/2
獲取到top和left的坐標不就居中了。
以下是居中的完整代碼:
這里要注意幾個問題,要設置元素的position的屬性為absolute,即絕對定位,然后添加兩個事件onload和onresize,要加上px的字符串,offsetHeight是獲取元素自身的高,offsetWidth是獲取元素自身的寬,這就是當網頁加載時和改變大小時div都會居中。不過這種做法是居中的元素和網頁的居中,如果想要一個元素在另一個元素的內部居中的話,原理是一樣的。我們只需要將網頁的寬和高的代碼改為另一個元素的寬和高的代碼就行了。另一個元素的寬和高可以通過獲取到當前元素的parent元素的高和寬。這樣也是可以居中的。如果用jquery這個框架,那么代碼就更簡單了。
轉載請指明出處。
先看一下居中的原理吧!
先看一張圖。

從圖中看到了什么?可以看到紅色的框居中了,為什么會居中呢?通過觀察可以發(fā)現紅框的上下的藍色的間距線是一樣長的,這樣可以確保了垂直居中,紅框的左右的綠色間距線也是一樣長的,這樣可以確保了水平居中。
但是怎么使上下的間距相等呢?左右的間距相等呢?
在看一張圖:

假設當前網頁的高為350px,寬為400px,而紅框的高為150px,寬為200px,我們可以發(fā)現網頁的高減去紅框元素的高得到200px像素,而這200px像素正是上下邊距的總和,上下邊距各得到了100px,同理,左右也是一樣的。
有沒有感覺到什么?
如果我們知道了網頁元素的高或寬,減去元素的高或寬,然后在除以2,就得到了上下左右邊距的距離。我們通常給元素的定位是怎么定的呢?不都是通過top和left的坐標定的嗎?那么現在紅框的坐標是什么呢?
再看一張圖:

紅色框的坐標是藍色的上線100px,和綠色的左線100px,即left和top的值,這兩個值不是算出來的嗎?
可以總結一個公式:
居中的元素的top =(網頁高 –元素的高)/ 2;
居中的元素的left= (網頁寬 –元素的寬) /2;
轉化為JavaScript的語法為:
top = (document.body.clientHeight - element.offsetHeight)/2;
left = (document.body.clientWidth - element.offsetWidth)/2
獲取到top和left的坐標不就居中了。
以下是居中的完整代碼:
這里要注意幾個問題,要設置元素的position的屬性為absolute,即絕對定位,然后添加兩個事件onload和onresize,要加上px的字符串,offsetHeight是獲取元素自身的高,offsetWidth是獲取元素自身的寬,這就是當網頁加載時和改變大小時div都會居中。不過這種做法是居中的元素和網頁的居中,如果想要一個元素在另一個元素的內部居中的話,原理是一樣的。我們只需要將網頁的寬和高的代碼改為另一個元素的寬和高的代碼就行了。另一個元素的寬和高可以通過獲取到當前元素的parent元素的高和寬。這樣也是可以居中的。如果用jquery這個框架,那么代碼就更簡單了。
轉載請指明出處。
相關文章
javascript獲取和判斷瀏覽器窗口、屏幕、網頁的高度、寬度等
這篇文章主要介紹了javascript獲取和判斷瀏覽器窗口、屏幕、網頁的高度、寬度等,需要的朋友可以參考下2014-05-05javascript跟隨滾動效果插件代碼(javascript Follow Plugin)
這篇文章介紹了javascript跟隨滾動效果插件代碼(javascript Follow Plugin),有需要的朋友可以參考一下2013-08-08JavaScript forEach中return失效問題解決方案
這篇文章主要介紹了JavaScript forEach中return失效問題解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-06-06