Promise

說明:
有了 Promise 對象,就能夠將異步操做以同步操做的流程表達出來,避免了層層嵌套的回調函數。
Promise 構造函數包含一個參數和一個帶有 resolve(解析)和 reject(拒絕)兩個參數的回調。在回調中執行一些操做,若是執行成功,則調用 resolve(),失敗調用 reject()。

Demo1:異步

methods: {
  startTodoTheProblem(){
      this.answerQuestion().then((result)=> {
            this.success(result) 
      }).catch((result)=>{
            this.failure(result)
      })		
  },
  answerQuestion(){
      return new Promise(function(resolve, reject){
            const number = 2 + 3
            number === 6 ? resolve('🍒') : reject('🐽')	
      })
  },
  success(value){
      alert('回答正確️'+ value)
  },
  failure(value){
      alert('回答錯誤'+ value)
  }
}
//Promise.resolve() ,Promise.reject()
//---------------------------------------log
//🐽

Demo2:函數

methods: {
  startCooking(){
      function cutUp(){
          console.log('Start cutting vegetables');
          var result = new Promise(function(resolve, reject){        //作一些異步操做
              setTimeout(function(){
                  console.log('Cut vegetables!');
                  resolve('🥕🥕🥕');
              }, 1000);
          });
        return result;
      }

      function boil(){
          console.log('Start boiling water');
          var result = new Promise(function(resolve, reject){        //作一些異步操做
              setTimeout(function(){
                  console.log('Boiling water!');
                  resolve('💧💧💧');
              }, 3000);
          });
        return result;
      }

      Promise.all([cutUp(), boil()])
          .then((result) => {
              console.log('ready');
              console.log(result);
           })
          .catch((error)={
              //.........
          }
      )
  }
}
//Promise.all()
//---------------------------------------log
//Start cutting vegetables
//Start boiling water
//Cut vegetables!
//Boiling water!
//["🥕🥕🥕", "💧💧💧"]

Demo3:this

methods:{
  startRunning(){
      function tortoise(){
          console.log('Tortoise Go');
          var result = new Promise(function(resolve, reject){        //作一些異步操做
              setTimeout(function(){
	          resolve('🐢');
	      }, 2000);
	   });
	return result;
      }

      function rabbit(){
          console.log('Rabbit Go!');
	  var result = new Promise(function(resolve, reject){        //作一些異步操做
	      setTimeout(function(){
	          resolve('🐇');
	      }, 1000);
	  });
	return result;
      }

      Promise.race([tortoise(), rabbit()])
          .then((result) => {
	      console.log(result + 'victory!!!');
	  })
	  .catch((error)={
	     //.........
	  }
      )
  }
}
//Promise.race()
//---------------------------------------log
// Tortoise Go
// Rabbit Go!
// 🐇victory!!!
相關文章
相關標籤/搜索