(42)JS運動之多物體架構--多個div變寬,jsdiv
如果只為div添加一個定時器的話,在多個div變寬的時候會發生問題,但是如果為每個div添加一個定時器,那麼就可以實現多個物體變寬。注意:在多物體運動的情況下,所有東西不能共用。offsetXXX會跟border衝突導致不能得到想要的結果,在這裡可以用getStyle()函數代替。
function getStyle(obj, name){if(obj.currentStyle){return obj.currentStyle[name];}else{return getComputedStyle(obj, false)[name];}}
<!DOCTYPE HTML><html><head><meta charset="utf-8"><title></title><style>div{width:100px;height:50px;background:red;margin:10px;}</style> <script>window.onload=function (){var aDiv=document.getElementsByTagName('div');for(var i=0;i<aDiv.length;i++){aDiv[i].timer=null;//自訂屬性,加一個定時器aDiv[i].onmouseover=function (){startMove(this,400);};aDiv[i].onmouseout=function (){startMove(this,100);};}};var timer=null;function startMove(obj, iTarget){clearInterval(obj.timer);obj.timer=setInterval(function (){var speed=(iTarget-obj.offsetWidth)/6;speed=speed>0?Math.ceil(speed):Math.floor(speed);if(obj.offsetWidth==iTarget){clearInterval(obj.timer);}else{obj.style.width=obj.offsetWidth+speed+'px';}}, 30);}</script></head><body > <div ></div> <div ></div> <div ></div> </body></html>:
我的div是float:left;多個div之間怎根據不同解析度平局間距,用js或jquery外掛程式都行
你是想做成流布局,還是說div並排固定要八個呢
1、如果是流布局,比如花瓣網,可以找專門的流布局jq包
2、如果需要固定八個div並排,就把div的寬度設定為百分比
①八個div百分比是width:12.5%;
②但是在ie6下,全寬是不到百分百的,所以只能設定到width:12.4%;
3、單純是要在120px的情況下增加,就要寫js的判斷了
首先判斷瀏覽器的寬度,然後減去div的總寬度再div的數量,得出一個剩餘分配的寬度,
最後設定div的寬度=120+剩餘分配的寬度
html css布局問題還是js運動架構問題?點擊讓li寬度變大,並讓span跑到緊貼div左側
在css裡做。設定li的浮動為左,也可設定li的寬度,高度設定要同行高的值一樣。再有把li設成塊