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

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

小球只移動了一次

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>promise animation</title>

<style>

.ball{

height: 40px;

width: 40px;

border-radius: 20px;

}

.ball1{

background: red;

}

.ball2{

background: yellow;

}

.ball3{

background: blue;

}

</style>

</head>

<body>

<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>

</body>

<!-- 引入Promise -->

<script type="text/javascript" src = '../node_modules/bluebird/js/browser/bluebird.js'></script>

<script>

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

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

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


function animate(ball, distance, callback) {

setTimeout(function () {

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

if (marginLeft === distance) {

callback && callback();

}else {

if (marginLeft < distance) {

marginLeft++;

}else {

marginLeft--;

}


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

animate(ball, distance, callback);

}

}, 13)

}


//exe fun ,ball move now

// callback hole

// animate(ball1,100,function(){

// ?animate(ball2,200,function(){

// ?animate(ball3,300,function(){

// ?animate(ball3,150,function(){

// ?animate(ball2,150,function(){

// ?animate(ball1,150,function(){


// ?})

// ?})

// ?})

// ?})

// ?})

// })


// 利用Promise來包裝函數,解決函數回調黑洞問題

// 引入Promise模塊

var Promise = window.Promise

// 利用Promise來包裝—_animate函數

function promiseAnimate(ball,distance){

return new Promise(function (resolve,rejecct) {

function _animate() {

setTimeout(function () {

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

if (marginLeft === distance) {

resolve

}else {

if (marginLeft < distance) {

marginLeft++;

}else {

marginLeft--;

}


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

_animate();

}

}, 13)

}

_animate()

})

}

// 使用Promise來執行函數

promiseAnimate(ball1,100)

.then(function(){

return promiseAnimate(ball2,200)

})

.then(function(){

return promiseAnimate(ball3,300)

})

.then(function(){

return promiseAnimate(ball3,150)

})

.then(function(){

return promiseAnimate(ball2,150)

})

.then(function(){

return promiseAnimate(ball1,150)

})



</script>

</html>


正在回答

2 回答

謝謝,,

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

http://img1.sycdn.imooc.com//5777cf8c000113d403730283.jpg

resolve 沒有調用~~~~~

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

舉報

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

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

進入課程

小球只移動了一次

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

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

幫助反饋 APP下載

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

公眾號

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