javascript - jquery each循环得到div的宽度,再赋值给父元素。结果为什么不对?
本文介绍了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
标签对放到dom
和js
之前
你的代码结构如果没有行内样式,会先把.aa
按照块级元素
处理,宽度为100%
js处理完成之后才读取style标签对,把.aa
处理为行内块级元素
,宽度缩短
同步的代码要把位置摆正确
这篇关于javascript - jquery each循环得到div的宽度,再赋值给父元素。结果为什么不对?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文