正常打包

import IndexPage from './views/app.jsx'
import AboutPage from './views/about.jsx'
export default function({history}) {
    return (
        <Router history={history}>
            <Route path="/" component={IndexPage} />
            <Route path="/about" component={AboutPage} />
        </Router>
    )
}

这是一个正常打包的路由写法, 如果需要分割代码, 我们需要改造下路由, 借助getComponentrequire.ensure

webpack 代码分割

export default function({history}) {
    return (
        <Router history={history}>
            <Route path="/" getComponent={(location, callback) => {
                require.ensure([], function(require) {
                    callback(null, require('./HomePage.jsx'))
                })
            }} />
            <Route path="/about" getComponent={(location, callback) => {
                require.ensure([], function(require) {
                    callback(null, require('./AboutPage.jsx'))
                })
            }} />
        </Router>
    )
}

这样看来代码有点累, 我们稍微改造下

const home = (location, callback) => {
  require.ensure([], require => {
    callback(null, require('./HomePage.jsx'))
  }, 'home')
}

const about = (location, callback) => {
  require.ensure([], require => {
    callback(null, require('./AboutPage.jsx'))
  }, 'about')
}
export default function({history}) {
    return (
        <Router history={history}>
            <Route path="/" getComponent={home}></Route>
            <Route path="/about" getComponent={about}></Route>
        </Router>
    )
}

这样看起来是不是简洁了很多

注意: 由于webpack的原因, 如果直接require('./AboutPage.jsx')不能正常加载, 请尝试require('./AboutPage.jsx').default

webpack2 代码分割

上面的代码看起来好像都是webpack1的写法, 那么webpack2呢?
webpac2就需要借助System.import

export default function({history}) {
    return (
        <Router history={history}>
            <Route path="/" getComponent={(location, callback) => {
                System.import('./HomePage.jsx').then(component => {
                    callback(null, component.default || component)
                })
            }} />
            <Route path="/about" getComponent={(location, callback) => {
                System.import('./AboutPage.jsx').then(component => {
                    callback(null, component.default || component)
                })
            }} />
        </Router>
    )
}

我们一样可以把上面的代码优化一下

const home = (location, callback) => {
    System.import('./HomePage.jsx').then(component => {
        callback(null, component.default || component)
    })
}
const about = (location, callback) => {
    System.import('./AboutPage.jsx').then(component => {
        callback(null, component.default || component)
    })
}

export default ({ history }) => {
    return (
        <Router history={history}>
            <Route name="home" path="/" getComponent={home} />
            <Route name="about" path="/about" getComponent={about} />
        </Router>
    )
}

webpack2 + dva 实现路由和 models 懒加载

const routerThen = (app, callback, [component, model]) => {
    app.model(model.default || model)
    callback(null, component.default || component)
}

export default ({ history, app }) => {
    return (
        <Router history={history}>
            <Route name="home" path="/" getComponent={(location, callback) => {
                Promise.all([
                    System.import('./views/app.jsx'),
                    System.import('./models/topics')
                ]).then(routerThen.bind(null, app, callback))
            }} />
            <Route name="article" path="/article/:id" getComponent={(location, callback) => {
                Promise.all([
                    System.import('./views/article.jsx'),
                    System.import('./models/topic')
                ]).then(routerThen.bind(null, app, callback))
            }} />
        </Router>
    )
}
发表评论
wayneliang
ssssss
sdsd
sdsd
dbears
挺好的
小马
dssdfsdf
小马
asd