javascript - How to define multiple views with parent child state using UI router? -


is possible define multiple views in child state parent child state relationship using ui-router?

i have following code in config

$urlrouterprovider.otherwise("/child");  $stateprovider   .state('parent', {     abstract: true,     views: {       'parent': {         templateurl: "parent.html",         controller: "parentctrl parentctrl"       },     }   })   .state('parent.child', {     url: '/child',     views: {       'state1@parent.child': {         templateurl: "child.html",         controller: "childctrl childctrl"       },      }   }); 

i verify parent.html showing up, child.html not

if move child.html parent views object like

$stateprovider   .state('parent', {     abstract: true,     views: {       'parent': {         templateurl: "parent.html",         controller: "parentctrl parentctrl"       },       'state1@parent.child': {         templateurl: "child.html",         controller: "childctrl childctrl"       },     }   }) 

than child.html works.

i verify using console.log($state.$current.name); in parentctrl current state parent.child.

can give me hint?

thanks

there a working plunker

i adjusted states , child views : {} this

$stateprovider   .state('parent', {     abstract: true,     views: {       'parent': {         templateurl: "parent.html",         controller: "parentctrl parentctrl"       },     }   })   .state('parent.child', {     url: '/child',     views: {       //'state1@parent.child': {       'view1@parent': {         templateurl: "child.html",         controller: "childctrl childctrl"       },       // same view2@parent       'view2': {         templateurl: "child.html",         controller: "childctrl childctrl"       },       'view3@': {         templateurl: "child.html",         controller: "childctrl childctrl"       },     } 

the construct '...@parent.child' wrong, because absolute naming... trying say, search ui-view="..." inside of 'parent.child' state. , not case.

so, let's place index:

// place parent <div ui-view="parent"></div> // place child view number 3 place in index  view 3    <div ui-view="view3"></div> 

and parent template this

<div ui-view="view1"></div> <div ui-view="view2"></div> 

then above state def target view1 absolute naming, same view3 - being in index.html; view2 go parent relative name

check here


Popular posts from this blog

php - How should I create my API for mobile applications (Needs Authentication) -

python 3.x - PyQt5 - Signal : pyqtSignal no method connect -

5 Reasons to Blog Anonymously (and 5 Reasons Not To)