注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

学会珍惜

You've been saying for the longest time

 
 
 

日志

 
 

javascript实现div垂直居中  

2013-01-15 17:38:29|  分类: 前端开发 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
改自互联网

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<title>javascript实现div垂直居中</title>
</head>
<body>
<div id="outer">要居中的内容</div>
<script type="text/javascript">
(function () {
var _undefined = undefined,
_null = null,
win = window,
doc = document,
_parseInt = parseInt,
_Math = Math,
prop_floor = 'floor',
prop_body = 'body',
prop_getElementById = 'getElementById',
prop_style = 'style',
prop_width = 'width',
prop_height = 'height',
prop_currentStyle = 'currentStyle',
prop_getComputedStyle = 'getComputedStyle',
prop_compatMode = 'compatMode',
prop_documentElement = 'documentElement',
prop_clientWidth = 'clientWidth',
prop_clientHeight = 'clientHeight',
prop_position = 'position',
prop_left = 'left',
prop_top = 'top',
_CSS1Compat = 'CSS1Compat',
_absolute = 'absolute',
_px = 'px';

function getSize(id) {
var cs = '', s = [], domId = doc[prop_getElementById](id);
s[0] = domId[prop_style][prop_width];
s[1] = domId[prop_style][prop_height];
if (s[0] == "") {
//外部CSS
if (domId[prop_currentStyle]) {
cs = domId[prop_currentStyle];
} else {
cs = win[prop_getComputedStyle](domId, _null);
}
s[0] = cs[prop_width];
}
if (s[1] == "") {
s[1] = cs[prop_height];
}
//去单位px
s[0] = _parseInt(s[0], 10);
s[1] = _parseInt(s[1], 10);
return s;
}

/*
把id放到pid中间
*/
function center(id, pid) {
var left, top, domId = doc[prop_getElementById](id);
var flag = (pid === _undefined || pid === _null || pid === "");
var p = [];
var s = getSize(id) || [];
if (flag) {
p[0] = doc[prop_compatMode] == _CSS1Compat ? doc[prop_documentElement][prop_clientWidth] : doc[prop_body][prop_clientWidth];
p[1] = doc[prop_compatMode] == _CSS1Compat ? doc[prop_documentElement][prop_clientHeight] : doc[prop_body][prop_clientHeight];
} else {
p = getSize(pid);
}
left = _Math[prop_floor]((p[0] - s[0]) / 2);
top = _Math[prop_floor]((p[1] - s[1]) / 2);
domId[prop_style][prop_position] = _absolute;
domId[prop_style][prop_left] = left + _px;
domId[prop_style][prop_top] = top + _px;
}
center('outer');
})();
</script>
</body>
</html>


  评论这张
 
阅读(152)| 评论(0)
推荐

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017