角js:解决依赖路线

weixin_38080567 2019-09-12 04:00:51

我有$ scope.question其中有问题的所有页面。 我想循环页面明智的问题。为此我写了一个函数questionsCtrl。这个函数我在配置路由时调用。 但在这里我得到了undefined。 请建议如何从$ scope.questions获取页面的数据。 app.js (function() { "use strict"; var app = angular.module("autoQuote",["ui.router","ngResource"]); app.config(["$stateProvider","$urlRouterProvider", function($stateProvider,$urlRouterProvider){ $urlRouterProvider.otherwise("/"); $stateProvider .state("step1", { url : "", controller: "questionsCtrl", resolve: { pageQuestion: $scope.questions } }) .state("step2", { url : "/step2", controller: "questionsCtrl", }) }] ); }()); questionCtrl.js (function() { "use strict"; angular .module("autoQuote") .controller("questionsCtrl",["$scope","$state","$q",questionsCtrl]); function questionsCtrl($scope,$state,$q) { console.log('here in get question for page: '+$state.current.name); //var deferred = $q.defer(); if($state.current.name == "" || $state.current.name == "step1") { $scope.pageQuestion = $scope.RC1_Cars_v2; } else if($state.current.name == "step2") { $scope.pageQuestion = $scope.RC1_Drivers_v2; } //return deferred.promise; console.log($scope); } }()); HTML <div class="container-fluid col-md-8"> <div ng-controller="autoQuoteCtrl"> <div ng-repeat="que in pageQuestion"> <!-- pagequestion will be in loop here --> </div> </div> </div> 这里是我完整的代码plunker http://plnkr.co/edit/kLc6DPqzQgLNpUBaLtZi?p=preview。






...全文
18 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
weixin_38112805 2019-09-12
  • 打赏
  • 举报
回复

视图的控制器包含视图特定的逻辑。如果您通过template或templateUrl向您的州添加模板,您将有权访问该模板中的控制器范围。就我所了解的问题而言,您希望在显示状态之前向您的内容提供数据。如果你看看在documentation决心财产是你在寻找什么: 您可以使用决心提供的内容或数据控制器是自定义的状态。 resolve是应该注入控制器的依赖关系的可选映射。 但是,您使用不正确。您将无法访问config区块中的$scope。你所要做的就是提供一个功能,你的决心属性,如下所示: resolve: { pageQuestion: function(myService) { return myService.getData(); } } 正如你可以在上面的代码段看到,我使用的注射一种名为myService的功能。该服务负责获取您的数据。在这个例子中,我假定该服务有一个方法getData,它返回一个承诺。在显示状态之前,ui路由器现在将等待所有承诺解决。一旦你创建了这样的功能,你可以使用你的解析属性的名称(在这种情况下pageQuestion)将你的数据注入你的视图控制器。所以你的问题控制器是这样的: function questionsCtrl(pageQuestion) { this.pageQuestion = pageQuestion; } 您只需注入你的决心到控制器中并将其分配到一个视图变量。 请注意,我假设您的状态为controllerAs语法,因此我可以在控制器内部省略$scope并直接使用this。所有您需要做的是一个属性controllerAs添加到您的状态,配置如下: .state("step1", { ... controller: "questionsCtrl", controllerAs: 'vm' }) 这样做的好处,你不会遇到的范围问题(这事做与范围继承)在长远来看。 This是关于示波器的绝佳文章。 你的观点应该是现在这个样子: <div class="container-fluid col-md-8"> <div ng-repeat="que in vm.pageQuestion"> <!-- pagequestion will be in loop here --> </div> </div> 在这里,您通过vm访问您的数据,它来自于你的状态配置的controllerAs财产。我还建议使用你的状态模板,并删除ng-controller的事件。你不会需要这个,因为你已经为你的状态声明了一个视图控制器。另外,ng-controller很难对你的状态进行财产管理。你最终得到一个范围内的汤,这是你明确想要避免的。

435

社区成员

发帖
与我相关
我的任务
社区描述
其他技术讨论专区
其他 技术论坛(原bbs)
社区管理员
  • 其他技术讨论专区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧