亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

代碼運行不了

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>Promise animation</title>

<style>

.ball{

width:40px;

? ? ? ? ? ? height:40px;

? ? ? ? ? ? border-radius: 20px;

? ? ? ? ? ? margin-left:0;

}

.ball1{background: red;}

.ball2{background: yellow;}

.ball3{background: green;}

</style>


</head>

<body>

<div class="ball ball1"></div>

<div class="ball ball2"></div>

<div class="ball ball3"></div>

<script>

var ball1=document.querySelector('.ball1');

var ball2=document.querySelector('.ball2');

var ball3=document.querySelector('.ball3');


function animate(ball,distance,cb){

setTimeout(function(){

var marginLeft=parseInt(ball.style.marginLeft,10);

if(marginLeft===distance){

cb&&cb()

}else{

if(marginLeft<distance){

marginLeft++

}else{

marginLeft--

}

ball.style.marginLeft=marginLeft+'px';

animate(ball,distance,cb);

}

},13)

}




animate(ball1,100,function(){

animate(ball2,200,function(){

animate(ball3,300,function(){

animate(ball3,150,function(){

animate(ball2,150,function(){

animate(ball1,150,function(){


})

})

})

})

})

})

</script>

</html>


正在回答

5 回答

????<div?class="ball?ball1"></div>
????<div?class="ball?ball2"></div>
????<div?class="ball?ball3"></div>

改成:

????<div?class="ball?ball1"?style="margin-left:0;"></div>
????<div?class="ball?ball2"?style="margin-left:0;"></div>
????<div?class="ball?ball3"?style="margin-left:0;"></div>

----------

.ball?{
????width:?40px;
????height:?40px;
????border-radius:?20px;
????margin-left:?0px;
}

改成:

.ball?{
????width:?40px;
????height:?40px;
????border-radius:?20px;
}


0 回復 有任何疑惑可以回復我~
#1

u5u75 提問者

非常感謝!
2016-10-24 回復 有任何疑惑可以回復我~

你的</body>呢?

0 回復 有任何疑惑可以回復我~

與加載有個毛關系。elment.style.marginLeft 意思僅僅是 取得 該元素的屬性 style(如果有), 的 margin-left(如果有)值。去 內聯樣式表的style屬性 FF or Chrome 用的是 window.getComputedStyle(element, null).getPropertyValue('margin-left')

0 回復 有任何疑惑可以回復我~
#1

飄移的鼻毛

我也贊同跟加載應該沒得啥子關系,但是確實是出問題了,怎么解決
2016-11-25 回復 有任何疑惑可以回復我~
#2

hey自然 回復 飄移的鼻毛

我不是已經給答復了么???既然用的是style獲取元素的margin值,那就用 行內樣式呀
2016-11-25 回復 有任何疑惑可以回復我~

應該與加載有關

0 回復 有任何疑惑可以回復我~
#1

u5u75 提問者

為什么我那個寫法不行啊
2016-10-24 回復 有任何疑惑可以回復我~
#2

我是大樹 回復 u5u75 提問者

放到<style>里的話,應該是所有內容加載完畢之后再應用樣式。估計是在<script>之后執行,所以直接被重置了。
2016-10-25 回復 有任何疑惑可以回復我~
#3

我是大樹 回復 u5u75 提問者

我的猜測。
2016-10-25 回復 有任何疑惑可以回復我~

跟我一樣的情況

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
進擊Node.js基礎(二)
  • 參與學習       76735    人
  • 解答問題       242    個

本教程帶你攻破 Nodejs,讓 JavaScript流暢運行在服務器端

進入課程

代碼運行不了

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號