php 获取0值,jquery offset()获取隐藏元素坐标值始终为0

2015-02-10 更新

----------------------------------------------------------------------------------------------------

Element.offset().top方法正常情况下是获得元素相对浏览器视窗之间的距离,但如果元素本身是隐藏的即加了display:none,该方法取得值始终都是0;

如代码所示:

*{margin:0;padding:0;}

body{height:2000px;}

.demo{width:200px;height:200px; border:1px red solid; position:absolute;right:0;top:200px; display:none;}

$(function(){

var temp=$(".demo").offset().top;

alert(temp);

})

alert出来的是0

解决方法:直接获取元素css中定义的top值,再去掉获取值中的px单位值,修改后的源码如下:

*{margin:0;padding:0;}

body{height:2000px;}

.demo{width:200px;height:200px; border:1px red solid; position:absolute;right:0;top:200px; display:none;}

$(function(){

var temp=$(".demo").css("top");

temp=stripPX(temp);

//去掉px

function stripPX(obj){

if(obj.indexOf("px")!=-1){

return parseInt(obj.slice(0,-2));

}else{

return "参数格式不正确!";

}

}

alert(temp);

})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值