zoukankan      html  css  js  c++  java
  • jQuery尺寸算法

    我们默认都统一是采用offsetWidth或者offsetHeight取值了,但我们知道关于这2个尺寸的算法是这样的:

    offsetWidth =  border-left-width + padding-left + width + padding-right + border-right-width; 
    offsetHeight =  border-top-width + padding-top + height + padding-bottom + border-bottom-width;

    不在考虑box-sizing:padding-box的情况下,也就差不多了。但是关于尺寸的接口不是还有

    innerWidth、innerHeight、outerWidth、outerHeight这些类似的处理吗?当然虽然都是获取尺寸还是有区别的。

    innerWidth、innerHeight

    用于获得匹配集合中第一个元素的当前计算的内部宽高(包括padding,但不包括border),或 设置每一个匹配元素的内部宽高。

    outerWidth、outerHeight

    获取元素集合中第一个元素的当前计算宽高度值,包括padding,border和选择性的margin

    针对这些情况,jQuery不得不给出一个方法用来去掉对应的值,这个是对应的augmentWidthOrHeight方法

    我们具体看看怎么计算的

    innerWidth = ele.offsetWidth –ele.borderRightWidth –ele.borderLeftWidth
    innerHeight = ele.offseHeight –ele.borderTopHeight –ele.borderBottomHeight

    outerWidth如果不传递参数,那么算法就跟innerWidth一样

    如果传递outerWidth(true)就需要加上margin

    outerWidth(true) = ele.offsetWidth + ele.marginLeft + ele.marginRight
    outerHeigth(true) = ele.offsetHeigth + ele.marginTop + ele.marginBottom

    关于jQuery6个尺寸方法的接口算法就是这样的了

  • 相关阅读:
    【回顾整理】HTML+CSS个的两个实战项目
    【转】tkinter实现的文本编辑器
    迟到的tkinter---学校选课刷屏器
    调用有道翻译API
    【leetCode】3Sum Closest
    【LeedCode】3Sum
    【LeedCode】String to integer(atoi)
    【LeetCode】Reverse digits of an integer
    前端工程师必备PS技能
    【LeetCode】Add Two Numbers
  • 原文地址:https://www.cnblogs.com/aaronjs/p/4155615.html
Copyright © 2011-2022 走看看