小编myk*_*age的帖子

Angular UI-Router $ urlRouterProvider.当不工作*时*

问题: 为什么不再.when()在我的$urlRouterProvider工作中?

我已经选择了一个相当强大的角应用程序.我一直试图解决的最新问题是"页面刷新时丢失的用户凭据"问题.

当我拿起它时,项目的auth服务没有多大意义,在挖掘之后我知道它是从几个随机页面的代码中组合而成的.它也没有完全工作,所以我调查了不同的来源并决定完全实现其中一个(angular-client-side-auth)

现在,我实现的auth服务/控制器基本上与angular-client-side-auth中的相同,但是我工作的站点使用基于令牌的身份验证.令牌功能已基本到位,所以我没有遇到任何麻烦.

在这一点上,我让用户保持登录状态刷新,路由正在与他们的身份验证一起工作(以前使用庞大的代码来禁用视图中的元素)但是,现在$urlRouterProvider .when()s已经破坏了.他们以前工作得很好,所以我知道我所做的就是错 - 但我不能简单地撤消我已实施的内容!

所以这是我正在使用的$ urlRouterProvider代码.值得一提的是我已经包含/需要了.when(),而angular-client-side-auth似乎并没有使用它们.我希望它们可以用该代码实现,但是它可能存在一些使得功能无效的东西.when()?我不这么认为.也可以澄清我还没有使用.rule或者$httpProvider.interceptors那里.我已尝试使用这些实现的网站,但它们似乎没有什么区别.

$urlRouterProvider
   .when('/myState/group', ['$state', 'myService', function ($state, myService) {
            $state.go('app.myState.group.id', {id: myService.Params.id});
   }])
   .otherwise('/');
Run Code Online (Sandbox Code Playgroud)

所以基本上,如果用户或网站指示用户/myState/group,他们实际上应该最终在url状态app.myState.group.id对吗?他们不是,我无法弄清楚为什么.关于使用urlRouterProvider的问题并不多.

什么没有发生?那么/myState/group负载的视图很好,并且在其中<ui-view>是生成的列表id.您可以单击一个ID,该ID调用一个设置ID的函数,然后执行$state.go('app.myState.group.id', {id: group.id, std: $scope.std1}); 该状态当然会替换用户单击的"生成列表".

现在,为了.state()......

.state('app.myState', {
            abstract: true,
            url: '/myState',
            templateUrl: 'views/myState.html',
            data: {
                access: access.user
            }, …
Run Code Online (Sandbox Code Playgroud)

javascript angularjs angular-ui-router

16
推荐指数
1
解决办法
1万
查看次数

AngularJS:控制器范围不会与promise同步

我已经选择了一个项目,我正在尝试将一些数据从服务返回到我的控制器.我已经在这里待了大约12个小时,并尝试了不同的方法.它们通常都会产生同样的"缺失数据".

我试过了

  • 使用$ resource而不是$ http
  • $http.get右侧放在控制器内而不使用promises
  • 服务作为实际服务(而不是工厂)没有返回
  • 建立工厂的一系列不同方式以各种格式返回数据
  • 使用setTimeout和$ apply

我觉得我现在所拥有的是一个简单的,因为我可以得到它,而我所读到的一切都说这应该有效

angularjs的负载数据从服务

角控制器斜面-GET-数据从服务

angularjs - 承诺 - 不烧时,返回-从一种服务

angularjs - 承诺 - 不解决,适当

angularjs-承诺

这些链接就是从今天开始的.

我认为可能存在$ scope问题,因为过去我已经看到$ scopes在使用多个控制器时没有获取数据,但是该站点只是在index.html中声明一个控制器作为<body ng-app="myApp" ng-controller="BodyCtrl">设置.主app.js使用状态(我认为来自ui-router)就像这样......

.state('app.view', {
    url: '/view',
    templateUrl: 'views/view.tpl.html',
    controller: 'MyCtrl'
   })
Run Code Online (Sandbox Code Playgroud)

将控制器连接到不同的页面.此外,该网站还有一些其他控制器从服务中获取数据,我首先将其作为模板查看,然而,数据和返回比我想要的更复杂.但最重要的是,控制器正在访问服务提供的数据.他们都使用$ resource,这就是我从这个问题开始的方式.我坚持使用$ http因为它应该可以工作,而且我希望在我进入"更高级别"的东西之前使用它.另外,我只需要从端点获取GET,所以觉得$ resource太过分了.

服务

.factory('MyService', ['$http', '$q', '$rootScope', function ($http, $q, $rootScope) {
    var defer = $q.defer();
    var factory = {};
    factory.all = function () {
        $http({method: 'GET', url: 'http://URLtoJSONEndpoint'}). …
Run Code Online (Sandbox Code Playgroud)

angularjs angularjs-service angularjs-scope angularjs-controller angularjs-http

6
推荐指数
1
解决办法
8113
查看次数