js 和 jquery 里面几个获取宽高的调查

罗列下 js 和 jquery 里面获取宽高的方法:

obj.offsetWidth = $obj.outerWidth()  // offsetWidth

obj.clientWidth = obj.scrollWidth   // offsetWidth - border - scrollbar

$obj.innerWidth()                            // offsetWidth - border

$obj.width()                                   // offsetWidth - border - padding

基本是这样(当然测试的过程复杂得多,移动端 scrollbar 为 0,是加法还是减法,还考虑 inline 形态等)...

css 是这样的 width:100px; padding: 15px; border: 5px solid; overflow:auto;

 

获取高度同理,此处不赘述...

可见 jquery 的 width() 方法和 js 的 clientWidth 还是有区别的,

可以认为当有滚动条时,子级的宽度会和 scrollbar 有关,而不是单纯的 offsetWidth - border - padding

而且 border-box 状态下这一切又不一样了...(JQuery 忽略了盒模式,Zepto 倒是由 box-sizing 决定)

 

另外,inline-block 形态与 block 一致

而 inline 状态时,clientWidth 和 scrollWidth 是为 0 的,但 width() 依然可用

 

再写点不错引用:

// 判断子级是否超出了父级范围
obj.scrollHeight > obj.clientHeight || obj.offsetHeight > obj.clientHeight; 

  

// 判断是否在屏幕中显示
$.fn.isInView = function(options) {
  var $this = $(this);

  if (!$this.visible()) return false;

  var windowLeft = $win.scrollLeft(), windowTop = $win.scrollTop();
  var offset = $this.offset();
  var left = offset.left, top = offset.top;

  options = $.extend({
    topOffset: 0, leftOffset: 0
  }, options);

  return (
    top + $this.height() >= windowTop &&
    top - options.topOffset <= windowTop + $win.height() &&
    left + $this.width() >= windowLeft &&
    left - options.leftOffset <= windowLeft + $win.width()
  );
};

  

转载于:https://www.cnblogs.com/foreverZ/p/5872662.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值