无法使用$ state.go发送数据

时间:2015-06-11 08:46:27

标签: angularjs ngroute

我在我的角应用程序中有这个代码。因此,正如代码所说,有多个视图被加载,我想传递一个参数。

.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

1 个答案:

答案 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});

有一个小错字错误。