# Lazy Loading Routes
When building apps with a bundler, the JavaScript bundle can become quite large, and thus affect the page load time. It would be more efficient if we can split each route's components into a separate chunk, and only load them when the route is visited.
Combining Kdu's async component feature (opens new window) and webpack's code splitting feature (opens new window), it's trivially easy to lazy-load route components.
First, an async component can be defined as a factory function that returns a Promise (which should resolve to the component itself):
const Foo = () =>
Promise.resolve({
/* component definition */
})
Second, in webpack 2, we can use the dynamic import (opens new window) syntax to indicate a code-split point:
import('./Foo.kdu') // returns a Promise
Note
if you are using Babel, you will need to add the syntax-dynamic-import (opens new window) plugin so that Babel can properly parse the syntax.
Combining the two, this is how to define an async component that will be automatically code-split by webpack:
const Foo = () => import('./Foo.kdu')
Nothing needs to change in the route config, just use Foo
as usual:
const router = new KduRouter({
routes: [{ path: '/foo', component: Foo }]
})
# Grouping Components in the Same Chunk
Sometimes we may want to group all the components nested under the same route into the same async chunk. To achieve that we need to use named chunks (opens new window) by providing a chunk name using a special comment syntax (requires webpack > 2.4):
const Foo = () => import(/* webpackChunkName: "group-foo" */ './Foo.kdu')
const Bar = () => import(/* webpackChunkName: "group-foo" */ './Bar.kdu')
const Baz = () => import(/* webpackChunkName: "group-foo" */ './Baz.kdu')
webpack will group any async module with the same chunk name into the same async chunk.