recherche

Maison  >  Questions et réponses  >  le corps du texte

angular.js - angular $q问题

function getMenus() {
    if (!localStorage.getItem('menus')) {
        var defer = $q.defer();
        $http.get('api/menu').success(function (res) {
            // scope.menuList = res;
            localStorage.setItem('menus', res)
            defer.resolve();
            return defer.promise;
        }).error(function (err) {
            defer.reject()
            return defer.promise;
        });

    }
}
getMenus().then(function () {
    scope.menuList = localStorage.getItem('menus')
})

返回结果是angular.min.js:107 TypeError: Cannot read property 'then' of undefined

请问哪里错了。。。。。

高洛峰高洛峰2744 Il y a quelques jours560

répondre à tous(2)je répondrai

  • 滿天的星座

    滿天的星座2017-05-15 17:08:27

    L'erreur est signalée car la fonction getMenus n'a pas de valeur de retour, js renvoie undéfini par défaut, puis se déclenche sur undéfini, donc l'erreur est signalée
    Solution :

    Initialiser dans la première ligne de getMenus

    var defer = $q.defer()

    Enfin, renvoyez defer.promise comme valeur de retour
    Cela devrait être le résultat final

    function getMenus() {
        var defer = $q.defer()
        if (...) {...}
        return defer.promise
    }

    Bien sûr, il y aura des problèmes si vous renvoyez des promesses dans les rappels de réussite et d'erreur

    répondre
    0
  • 巴扎黑

    巴扎黑2017-05-15 17:08:27

    function getMenus() {
    
        var defer = $q.defer();
        
        if (!localStorage.getItem('menus')) {
            
            $http.get('api/menu').success(function (res) {
                // scope.menuList = res;
                localStorage.setItem('menus', res)
                defer.resolve();
            }).error(function (err) {
                defer.reject()
            });
    
        }
        
        return defer.promise;
    }

    répondre
    0
  • Annulerrépondre