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
请问哪里错了。。。。。
滿天的星座2017-05-15 17:08:27
getMenus 関数には戻り値がなく、js はデフォルトで undefined を返し、その後、未定義の場合に発生するため、エラーが報告されます
解決策:
getMenusの最初の行で初期化されます
リーリー最後に戻り値としてdefer.promiseを返します
最終的にはこんな感じになるはずです
もちろん、成功コールバックとエラーコールバックで Promise を返すと問題が発生します