bei der Verwendung von $q.defer() in Angularjs

Ich bin neu in Angularjs und ich bin nach diesem tutorial :http://mherman.org/blog/2015/07/02/handling-user-authentication-with-the-mean-stack/#.WE70iubhCM8 . Aber ich verstehe nicht, Wann $q.defer(). Zum Beispiel in der folgenden Angularjs-code, warum verwenden Sie "$q".defer() :

function login(username, password) {

      //create a new instance of deferred
      var deferred = $q.defer();

      //send a post request to the server
      $http.post('/user/login',
        {username: username, password: password})
        //handle success
        .success(function (data, status) {
          if(status === 200 && data.status){
            user = true;
            deferred.resolve();
          } else {
            user = false;
            deferred.reject();
          }
        })
        //handle error
        .error(function (data) {
          user = false;
          deferred.reject();
        });

Den server-side-code ist :

router.post('/login', function(req, res, next) {
  passport.authenticate('local', function(err, user, info) {
    if (err) {
      return next(err);
    }
    if (!user) {
      return res.status(401).json({
        err: info
      });
    }
    req.logIn(user, function(err) {
      if (err) {
        return res.status(500).json({
          err: 'Could not log in user'
        });
      }
      res.status(200).json({
        status: 'Login successful!'
      });
    });
  })(req, res, next);
});

Und warum nicht verwenden Sie es in der folgenden Angularjs-code :

 function getUserStatus() {
      return $http.get('/user/status')
      //handle success
      .success(function (data) {
        if(data.status){
          user = true;
        } else {
          user = false;
        }
      })
      //handle error
      .error(function (data) {
        user = false;
      });
    }

Server-side-code ist :

router.get('/status', function(req, res) {
  if (!req.isAuthenticated()) {
    return res.status(200).json({
      status: false
    });
  }
  res.status(200).json({
    status: true
  });
});
Fast verwenden Sie nie! Nicht aus diesem Beispiel lernen, es setzt ein weithin bekannter antipattern.

InformationsquelleAutor juliana Morales | 2016-12-12

Schreibe einen Kommentar