How to update AngularJS state asynchronously using value inside Promise

How can I access the return value from () in JavaScript?

I have the following function:

function getResult(){
  var promise = _myService.getAge();
  var getResultPromise = promise.then(function(age){
    return age;
  })
  return getResultPromise; //How do i get the age (value) here?  *see image*
}

      

Or how do I access the value in the $$ state object below?

enter image description here

+3


source to share


1 answer


How about this:



//The simple solution, this is how to use a Promise:

let _myService = {
  getAge: function() {
    return new Promise(function(resolve, reject) {
      setTimeout(function() {
        resolve(3)
      }, 500);
    })
  }
};

function getResult() {
  _myService.getAge().then(function(age) {
    console.log(age);
  });
}

getResult();

//OR, maybe closer to OP intended implementation, put the value in an outer state:

let outerState = {
  age: 0
};

setTimeout(function() {
  console.log(outerState)
}, 450);

let _myService2 = {
  getAge: function() {
    return new Promise(function(resolve, reject) {
      setTimeout(function() {
        resolve(8)
      }, 750);
    })
  }
};

function addAgeToOuterState() {
  pState = new Promise(function(resolve, reject) {
    _myService2.getAge().then(function(newAge) {
      outerState.age = newAge;
      resolve(outerState);
    });
  });

  pState.then(function() {
    console.log(outerState);
  });

  return pState;
}

addAgeToOuterState()

//for fun
.then(function(outer) {
  console.log(outer); //state is still here
});
      

Run codeHide result


-2


source







All Articles