javascript - jquery each循环得到div的宽度,再赋值给父元素。结果为什么不对?

查看:245
本文介绍了javascript - jquery each循环得到div的宽度,再赋值给父元素。结果为什么不对?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

<script src="jquery.js"></script>
<div id="a1">
    <div class="aa" style="width: 200px;">423423423423423423423</div>
    <div class="aa" style="width: 180px;">42342342342342342</div>
    <div class="aa" style="width: 150px;">123123</div>
</div>
<script>
var w = 0
$("#a1 .aa").each(function(){
    w += $("#a1 .aa").width();//获取宽度。并累加
})
$("#a1").width(w)
</script>
<style>
    .aa{
        display: inline-block;
    }
</style>

本来结果应该是这样的的

但是把行内样式去掉之后,结果就好大了。

为什么把行内样式去掉。就这样了呢????

解决方案

style标签对放到domjs之前
你的代码结构如果没有行内样式,会先把.aa按照块级元素处理,宽度为100%
js处理完成之后才读取style标签对,把.aa处理为行内块级元素,宽度缩短
同步的代码要把位置摆正确

这篇关于javascript - jquery each循环得到div的宽度,再赋值给父元素。结果为什么不对?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆