我在我的角应用程序中有这个代码。因此,正如代码所说,有多个视图被加载,我想传递一个参数。
.state('root.moduleListing', {
params: ['registerData'],
views: {
"main_container": {
controller: 'ModuleListingController as model',
templateUrl: 'misc/module-listing/module-listing.tpl.html',
resolve: {
registerData: ['$stateParams', function($stateParams) {
return $stateParams.registerData;
}]
}
},
"components_header_header": {
controller: 'HeaderController as model',
templateUrl: 'components/header/post-login.tpl.html',
},
"components_footer_footer": {
controller: 'FooterController as model',
templateUrl: 'components/footer/footer.tpl.html',
}
}
}
&安培;我用
来称呼它$state.go('root.moduleListing', {'registerdata': response});
&安培;在控制器中,我只是想将它记录到控制台。
module.controller('ModuleListingController', function ($scope, $state, registerData) {
var model = this;
console.log("registerData : " + registerData);
}
现在应用程序甚至没有启动,即我在控制台中收到错误消息:
failed to instantiate module amcatUI due to:
TypeError: id.match is not a function
at getArrayMode
答案 0 :(得分:5)
$ state.go的已定义参数和toParamas的类型应该是状态转换两侧的相同数组或对象。只需在状态定义中使用默认值添加参数即可。
您需要从
更新代码params: ['registerData'],
到
params: {'registerData' : null},
有关详细解答,请参阅“https://stackoverflow.com/a/26204095/1132354”。
修改
此外,您还需要更新
$state.go('root.moduleListing', {'registerdata': response});
到
$state.go('root.moduleListing', {'registerData': response});
有一个小错字错误。