I am trying to put together a demo app of Angular 2 + Rx.JS 5/Next.
I noticed that my components are re-instantiated each time I switch the route.
It is absolutely expected behavior that the components will be constructed and destructed as your route changes.
Remember, components are closely associated with the DOM elements of your templates. As these dom elements are removed or changed, so must the component be destructed and a new one constructed.
There are a few exceptions to this, but not as it relates to your use-case (for example the CanReuse
method mentioned in another answer, but that's meant for something completely different.
What CanReuse
does, is when going from a route (let's call it route1
) to another route (route2
), and both routes use the same component MyComponent
, if you tell it that it's allowed to re-use the component, it is basically saying:
"Since the route I'm going too uses the exact same component type as the route I'm currently on, it's ok to reuse my current component instance on the new route" (perhaps because it's stateless for example).
You don't say exactly what you are trying to achieve, or why it is important for your two components to be instantiated only once, but in general, components are not intended to store long-term application state (or more precisely, state that outlives the lifetime of the dom element associated with the component). These sort of things should live elsewhere (e.g. in services) and shared between components through injection (or passed in as Inputs).
>= 2.3.0-rc.0
A custom RouteReuseStrategy
can be implemented to control when routed components are destroyed and recreated or reused.
>= 2.0.0
CanReuse
doesn't exist anymore in the new router. When only route parameters change while staying on the same route, the component is not recreated.
If the route is changed and navigated back to the same component the component is recreated.
<=RC.x
Note that I have explicitly required that the First and Second components be instantiated at the root-level component by adding a providers array there.
Adding components to providers: []
is mostly meaningless especially in regard to this issue.
You can implement CanReuse
by adding
routerCanReuse(next: ComponentInstruction, prev: ComponentInstruction) { return true; }
to your component, but it's quite limited for which kind of navigation the same instance is reused (if you stay on the same route and only change parameters).
If CanReuse
doesn't fix your problem then move the data to a service, where instances are kept and bind the view of the component to the data of this service to make the component show current data.
"It is absolutely expected behavior that the components will be constructed and destructed as your route changes"
The point is that components should NOT be reconstructed again and again as one navigates back and forth between two links (that are different from each other). What if you have complex graphics and state that you are modifying on one link and the object is destroyed and recreated as you arrive back to resume your work?
A framework should not dictate if the objects should be destroyed and recreated again and again. It should provide both options and in the default option, it should NOT destroy and recreate as this is the intuitive behavior. This is the behavior most UI frameworks have used over the years.