$state.转到带有 URL 参数的状态



我有一个带有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

最新更新