原生js实现jQuery的功能 width()方法实现 (二)

上一篇介绍了height()方法的实现,这一篇介绍下width()的方法实现。
其实基本类似,直接看代码吧。如果需要了解原理请看height()的方法实现细节。

  getElWidth: function (elObj) {
        //如果传入的不是对象是字符串 则通过字符串转换成对象
        elObj = GoingUtils.getElObj(elObj);
        if (elObj != null&&GoingUtils.isShow(elObj)) {
            //如果标签上定义了style 而且style里面定义了width 则返回width
            if (elObj.style.width != null && elObj.style.width.length > 0) {
                return parseFloat(elObj.style.width);
            }
            //如果elObj.style.width为空  则从css里面获取是否定义了width信息如果定义了 则读取css里面定义的宽度width
            if(parseFloat(GoingUtils._getStyleValue(elObj,"width"))>0) {
                return parseFloat(GoingUtils._getStyleValue(elObj,"width"));
            }
            //如果从css里获取到的值不是大于0  可能是auto 则通过offsetWidth来进行计算
            if (elObj.offsetWidth > 0) {
                var borderLeftWidth = GoingUtils._getStyleValue(elObj, "borderLeftWidth");
                var borderRightWidth = GoingUtils._getStyleValue(elObj, "borderRightWidth");
                var paddingLeft = GoingUtils._getStyleValue(elObj, "paddingLeft");
                var paddingRight = GoingUtils._getStyleValue(elObj, "paddingRight")
                var backWidth = parseFloat(elObj.offsetWidth) - parseFloat(borderLeftWidth) - parseFloat(borderRightWidth) - parseFloat(paddingLeft) - parseFloat(paddingRight);
                return parseFloat(backWidth);
            }
            return 0;
        } else {
            //将元素显示出来 获取高度 再将元素隐藏掉 注意这里的inline-block  如果是block就是整个宽度了
            GoingUtils.attrEl(elObj,'style',"visibility:hidden;display:inline-block !important;");
            var width=GoingUtils.getElWidth(elObj);
            elObj.removeAttribute('style');
            return Math.ceil(width);
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值