Browse Source

Merge pull request #486 from HeroProtagonist/code-split-example-edit

Properly nest components in router
main
Alex 7 years ago
committed by GitHub
parent
commit
60faba4e8e
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 18
      content/docs/code-splitting.md

18
content/docs/code-splitting.md

@ -41,7 +41,7 @@ console.log(add(16, 26)); // 42
``` ```
> Note: > Note:
> >
> Your bundles will end up looking a lot different than this. > Your bundles will end up looking a lot different than this.
If you're using [Create React App](https://github.com/facebookincubator/create-react-app), [Next.js](https://github.com/zeit/next.js/), [Gatsby](https://www.gatsbyjs.org/), or a similar tool, you will have a Webpack setup out of the box to bundle your If you're using [Create React App](https://github.com/facebookincubator/create-react-app), [Next.js](https://github.com/zeit/next.js/), [Gatsby](https://www.gatsbyjs.org/), or a similar tool, you will have a Webpack setup out of the box to bundle your
@ -59,7 +59,7 @@ if you are including large third-party libraries. You need to keep an eye on
the code you are including in your bundle so that you don't accidentally make the code you are including in your bundle so that you don't accidentally make
it so large that your app takes a long time to load. it so large that your app takes a long time to load.
To avoid winding up with a large bundle, it's good to get ahead of the problem To avoid winding up with a large bundle, it's good to get ahead of the problem
and start "splitting" your bundle. and start "splitting" your bundle.
[Code-Splitting](https://webpack.js.org/guides/code-splitting/) is a feature [Code-Splitting](https://webpack.js.org/guides/code-splitting/) is a feature
supported by bundlers like Webpack and Browserify (via supported by bundlers like Webpack and Browserify (via
@ -68,7 +68,7 @@ multiple bundles that can be dynamically loaded at runtime.
Code-splitting your app can help you "lazy-load" just the things that are Code-splitting your app can help you "lazy-load" just the things that are
currently needed by the user, which can dramatically improve the performance of currently needed by the user, which can dramatically improve the performance of
your app. While you haven't reduced the overall amount of code in your app, your app. While you haven't reduced the overall amount of code in your app,
you've avoided loading code that the user may never need, and reduced the amount you've avoided loading code that the user may never need, and reduced the amount
of code needed during the initial load. of code needed during the initial load.
@ -94,7 +94,7 @@ import("./math").then(math => {
``` ```
> Note: > Note:
> >
> The dynamic `import()` syntax is a ECMAScript (JavaScript) > The dynamic `import()` syntax is a ECMAScript (JavaScript)
> [proposal](https://github.com/tc39/proposal-dynamic-import) not currently > [proposal](https://github.com/tc39/proposal-dynamic-import) not currently
> part of the language standard. It is expected to be accepted within the > part of the language standard. It is expected to be accepted within the
@ -116,7 +116,7 @@ parse the dynamic import syntax but is not transforming it. For that you will ne
### React Loadable ### React Loadable
[React Loadable](https://github.com/thejameskyle/react-loadable) wraps [React Loadable](https://github.com/thejameskyle/react-loadable) wraps
dynamic imports in a nice, React-friendly API for introducing code dynamic imports in a nice, React-friendly API for introducing code
splitting into your app at a given component. splitting into your app at a given component.
**Before:** **Before:**
@ -167,7 +167,7 @@ libraries like [React Router](https://reacttraining.com/react-router/) and
[React Loadable](https://github.com/thejameskyle/react-loadable). [React Loadable](https://github.com/thejameskyle/react-loadable).
```js ```js
import { BrowserRouter as Router, Route } from 'react-router-dom'; import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';
import Loadable from 'react-loadable'; import Loadable from 'react-loadable';
const Loading = () => <div>Loading...</div>; const Loading = () => <div>Loading...</div>;
@ -184,8 +184,10 @@ const About = Loadable({
const App = () => ( const App = () => (
<Router> <Router>
<Route exact path="/" component={Home}/> <Switch>
<Route path="/about" component={About}/> <Route exact path="/" component={Home}/>
<Route path="/about" component={About}/>
</Switch>
</Router> </Router>
); );
``` ```

Loading…
Cancel
Save