我有一个带有url参数的状态。像这样:
.state('MyState', {
url: '/contacts/{personName}',
templateUrl: '/app/templates/contacts.html',
controller: 'ContactsController',
params: {
personName: null
}
})
现在,我想使用 $state.go
语法,并能够将personName
参数传递给带有参数的 url。
例如,如果我打电话:
$state.go('MyState', {personName: 'john'});
地址栏将显示:http://localhost:8080/#!/contacts/john
现在地址栏显示 http://localhost:8080/#!/contacts/,我不知道如何强制 url 包含personName
。除此之外,它工作正常。
只需在状态定义中添加具有默认值的参数即可。您的州仍然可以具有 Url 值。
$stateProvider.state('MyState', {
url : '/url',
templateUrl : "/app/templates/contacts.html",
controller : 'ContactsController',
params: {personName: 'defaultName'}
});
并将参数添加到 $state.go(( 并导航
$state.go('MyState',{personName: "MIT"});
参考这个:$state.go(( 与参数
希望对您有所帮助..!
在你的状态定义中,当你定义"params"时,你不必在url中添加参数,所以替换:
url: '/contacts/{personName}',
跟
url: '/contacts',
定义状态时使用以下语法
.state('myState', {
url: '/contacts/:personName',
templateUrl: '/app/templates/contacts.html',
controller: 'ContactsController',
params: {
personName: {
array: false
}
}
})
注意:"人名在网址中可见">
参考: https://ui-router.github.io/ng1/tutorial/helloworld