1
0
Fork 0
mirror of https://github.com/terribleplan/next.js.git synced 2024-01-19 02:48:18 +00:00

Change anynymous functions to named functions on examples in the README.md file (#6255)

* convert export default anonymous functions into named functions

* change examples to function declaration and split export in classes

* change NextHead name to Head and rename component
This commit is contained in:
Juan Olvera 2019-02-11 17:04:05 -06:00 committed by Tim Neutkens
parent e1056e32cf
commit 23c9c0d624

View file

@ -115,7 +115,11 @@ After that, the file-system is the main API. Every `.js` file becomes a route th
Populate `./pages/index.js` inside your project: Populate `./pages/index.js` inside your project:
```jsx ```jsx
export default () => <div>Welcome to next.js!</div> function Home() {
return <div>Welcome to next.js!</div>
}
export default Home
``` ```
and then just run `npm run dev` and go to `http://localhost:3000`. To use another port, you can run `npm run dev -- -p <your port here>`. and then just run `npm run dev` and go to `http://localhost:3000`. To use another port, you can run `npm run dev -- -p <your port here>`.
@ -136,11 +140,15 @@ Every `import` you declare gets bundled and served with each page. That means pa
```jsx ```jsx
import cowsay from 'cowsay-browser' import cowsay from 'cowsay-browser'
export default () => ( function CowsayHi() {
return (
<pre> <pre>
{cowsay.say({ text: 'hi there!' })} {cowsay.say({ text: 'hi there!' })}
</pre> </pre>
) )
}
export default CowsayHi
``` ```
### CSS ### CSS
@ -159,7 +167,8 @@ export default () => (
We bundle [styled-jsx](https://github.com/zeit/styled-jsx) to provide support for isolated scoped CSS. The aim is to support "shadow CSS" similar to Web Components, which unfortunately [do not support server-rendering and are JS-only](https://github.com/w3c/webcomponents/issues/71). We bundle [styled-jsx](https://github.com/zeit/styled-jsx) to provide support for isolated scoped CSS. The aim is to support "shadow CSS" similar to Web Components, which unfortunately [do not support server-rendering and are JS-only](https://github.com/w3c/webcomponents/issues/71).
```jsx ```jsx
export default () => ( function HelloWorld() {
return (
<div> <div>
Hello world Hello world
<p>scoped!</p> <p>scoped!</p>
@ -183,6 +192,9 @@ export default () => (
`}</style> `}</style>
</div> </div>
) )
}
export default HelloWorld
``` ```
Please see the [styled-jsx documentation](https://www.npmjs.com/package/styled-jsx) for more examples. Please see the [styled-jsx documentation](https://www.npmjs.com/package/styled-jsx) for more examples.
@ -208,7 +220,11 @@ Please see the [styled-jsx documentation](https://www.npmjs.com/package/styled-j
It's possible to use any existing CSS-in-JS solution. The simplest one is inline styles: It's possible to use any existing CSS-in-JS solution. The simplest one is inline styles:
```jsx ```jsx
export default () => <p style={{ color: 'red' }}>hi there</p> function HiThere() {
return <p style={{ color: 'red' }}>hi there</p>
}
export default HiThere
``` ```
To use more sophisticated CSS-in-JS solutions, you typically have to implement style flushing for server-side rendering. We enable this by allowing you to define your own [custom `<Document>`](#user-content-custom-document) component that wraps each page. To use more sophisticated CSS-in-JS solutions, you typically have to implement style flushing for server-side rendering. We enable this by allowing you to define your own [custom `<Document>`](#user-content-custom-document) component that wraps each page.
@ -227,7 +243,11 @@ To support importing `.css`, `.scss`, `.less` or `.styl` files you can use these
Create a folder called `static` in your project root directory. From your code you can then reference those files with `/static/` URLs: Create a folder called `static` in your project root directory. From your code you can then reference those files with `/static/` URLs:
```jsx ```jsx
export default () => <img src="/static/my-image.png" alt="my image" /> function MyImage() {
return <img src="/static/my-image.png" alt="my image" />
}
export default MyImage
``` ```
_Note: Don't name the `static` directory anything else. The name is required and is the only directory that Next.js uses for serving static assets._ _Note: Don't name the `static` directory anything else. The name is required and is the only directory that Next.js uses for serving static assets._
@ -249,7 +269,8 @@ We expose a built-in component for appending elements to the `<head>` of the pag
```jsx ```jsx
import Head from 'next/head' import Head from 'next/head'
export default () => ( function IndexPage() {
return (
<div> <div>
<Head> <Head>
<title>My page title</title> <title>My page title</title>
@ -258,6 +279,9 @@ export default () => (
<p>Hello world!</p> <p>Hello world!</p>
</div> </div>
) )
}
export default IndexPage
``` ```
To avoid duplicate tags in your `<head>` you can use the `key` property, which will make sure the tag is only rendered once: To avoid duplicate tags in your `<head>` you can use the `key` property, which will make sure the tag is only rendered once:
@ -265,7 +289,8 @@ To avoid duplicate tags in your `<head>` you can use the `key` property, which w
```jsx ```jsx
import Head from 'next/head' import Head from 'next/head'
export default () => ( function IndexPage() {
return (
<div> <div>
<Head> <Head>
<title>My page title</title> <title>My page title</title>
@ -277,6 +302,9 @@ export default () => (
<p>Hello world!</p> <p>Hello world!</p>
</div> </div>
) )
}
export default IndexPage
``` ```
In this case only the second `<meta name="viewport" />` is rendered. In this case only the second `<meta name="viewport" />` is rendered.
@ -301,7 +329,7 @@ When you need state, lifecycle hooks or **initial data population** you can expo
```jsx ```jsx
import React from 'react' import React from 'react'
export default class extends React.Component { class HelloUA extends React.Component {
static async getInitialProps({ req }) { static async getInitialProps({ req }) {
const userAgent = req ? req.headers['user-agent'] : navigator.userAgent const userAgent = req ? req.headers['user-agent'] : navigator.userAgent
return { userAgent } return { userAgent }
@ -315,6 +343,8 @@ export default class extends React.Component {
) )
} }
} }
export default HelloUA
``` ```
Notice that to load data when the page loads, we use `getInitialProps` which is an [`async`](https://zeit.co/blog/async-and-await) static method. It can asynchronously fetch anything that resolves to a JavaScript plain `Object`, which populates `props`. Notice that to load data when the page loads, we use `getInitialProps` which is an [`async`](https://zeit.co/blog/async-and-await) static method. It can asynchronously fetch anything that resolves to a JavaScript plain `Object`, which populates `props`.
@ -335,10 +365,9 @@ _Note: `getInitialProps` can **not** be used in children components. Only in `pa
You can also define the `getInitialProps` lifecycle method for stateless components: You can also define the `getInitialProps` lifecycle method for stateless components:
```jsx ```jsx
const Page = ({ stars }) => function Page({ stars }) {
<div> return <div>Next stars: {stars}</div>
Next stars: {stars} }
</div>
Page.getInitialProps = async ({ req }) => { Page.getInitialProps = async ({ req }) => {
const res = await fetch('https://api.github.com/repos/zeit/next.js') const res = await fetch('https://api.github.com/repos/zeit/next.js')
@ -384,7 +413,8 @@ Consider these two pages:
// pages/index.js // pages/index.js
import Link from 'next/link' import Link from 'next/link'
export default () => ( function Home() {
return (
<div> <div>
Click{' '} Click{' '}
<Link href="/about"> <Link href="/about">
@ -393,11 +423,18 @@ export default () => (
to read more to read more
</div> </div>
) )
}
export default Home
``` ```
```jsx ```jsx
// pages/about.js // pages/about.js
export default () => <p>Welcome to About!</p> function About() {
return <p>Welcome to About!</p>
}
export default About
``` ```
**Custom routes (using props from URL)** **Custom routes (using props from URL)**
@ -414,7 +451,7 @@ Example:
2. You created the `pages/post.js` 2. You created the `pages/post.js`
```jsx ```jsx
export default class extends React.Component { class Post extends React.Component {
static async getInitialProps({query}) { static async getInitialProps({query}) {
console.log('SLUG', query.slug) console.log('SLUG', query.slug)
return {} return {}
@ -423,6 +460,8 @@ Example:
return <h1>My blog post</h1> return <h1>My blog post</h1>
} }
} }
export default Post
``` ```
3. You add the route to `express` (or any other server) on `server.js` file (this is only for SSR). This will route the url `/post/:slug` to `pages/post.js` and provide `slug` as part of query in getInitialProps. 3. You add the route to `express` (or any other server) on `server.js` file (this is only for SSR). This will route the url `/post/:slug` to `pages/post.js` and provide `slug` as part of query in getInitialProps.
@ -463,7 +502,8 @@ The component `<Link>` can also receive an URL object and it will automatically
// pages/index.js // pages/index.js
import Link from 'next/link' import Link from 'next/link'
export default () => ( function Home() {
return (
<div> <div>
Click{' '} Click{' '}
<Link href={{ pathname: '/about', query: { name: 'Zeit' } }}> <Link href={{ pathname: '/about', query: { name: 'Zeit' } }}>
@ -472,6 +512,9 @@ export default () => (
to read more to read more
</div> </div>
) )
}
export default Home
``` ```
That will generate the URL string `/about?name=Zeit`, you can use every property as defined in the [Node.js URL module documentation](https://nodejs.org/api/url.html#url_url_strings_and_url_objects). That will generate the URL string `/about?name=Zeit`, you can use every property as defined in the [Node.js URL module documentation](https://nodejs.org/api/url.html#url_url_strings_and_url_objects).
@ -484,7 +527,8 @@ The default behaviour for the `<Link>` component is to `push` a new url into the
// pages/index.js // pages/index.js
import Link from 'next/link' import Link from 'next/link'
export default () => ( function Home() {
return (
<div> <div>
Click{' '} Click{' '}
<Link href="/about" replace> <Link href="/about" replace>
@ -493,6 +537,9 @@ export default () => (
to read more to read more
</div> </div>
) )
}
export default Home
``` ```
##### Using a component that supports `onClick` ##### Using a component that supports `onClick`
@ -503,7 +550,8 @@ export default () => (
// pages/index.js // pages/index.js
import Link from 'next/link' import Link from 'next/link'
export default () => ( function Home() {
return (
<div> <div>
Click{' '} Click{' '}
<Link href="/about"> <Link href="/about">
@ -511,6 +559,9 @@ export default () => (
</Link> </Link>
</div> </div>
) )
}
export default Home
``` ```
##### Forcing the Link to expose `href` to its child ##### Forcing the Link to expose `href` to its child
@ -523,13 +574,17 @@ If child is an `<a>` tag and doesn't have a href attribute we specify it so that
import Link from 'next/link' import Link from 'next/link'
import Unexpected_A from 'third-library' import Unexpected_A from 'third-library'
export default ({ href, name }) => ( function NavLink({ href, name }) {
return (
<Link href={href} passHref> <Link href={href} passHref>
<Unexpected_A> <Unexpected_A>
{name} {name}
</Unexpected_A> </Unexpected_A>
</Link> </Link>
) )
}
export default NavLink
``` ```
##### Disabling the scroll changes to top on page ##### Disabling the scroll changes to top on page
@ -558,11 +613,15 @@ You can also do client-side page transitions using the `next/router`
```jsx ```jsx
import Router from 'next/router' import Router from 'next/router'
export default () => ( function ReadMore() {
return (
<div> <div>
Click <span onClick={() => Router.push('/about')}>here</span> to read more Click <span onClick={() => Router.push('/about')}>here</span> to read more
</div> </div>
) )
}
export default ReadMore
``` ```
#### Intercepting `popstate` #### Intercepting `popstate`
@ -615,11 +674,15 @@ const handler = () => {
}) })
} }
export default () => ( function ReadMore() {
return (
<div> <div>
Click <span onClick={handler}>here</span> to read more Click <span onClick={handler}>here</span> to read more
</div> </div>
) )
}
export default ReadMore
``` ```
This uses the same exact parameters as in the `<Link>` component. This uses the same exact parameters as in the `<Link>` component.
@ -724,7 +787,7 @@ If you want to access the `router` object inside any component in your app, you
```jsx ```jsx
import { withRouter } from 'next/router' import { withRouter } from 'next/router'
const ActiveLink = ({ children, router, href }) => { function ActiveLink({ children, router, href }) {
const style = { const style = {
marginRight: 10, marginRight: 10,
color: router.pathname === href ? 'red' : 'black' color: router.pathname === href ? 'red' : 'black'
@ -773,8 +836,8 @@ You can add `prefetch` prop to any `<Link>` and Next.js will prefetch those page
```jsx ```jsx
import Link from 'next/link' import Link from 'next/link'
// example header component function Header() {
export default () => ( return (
<nav> <nav>
<ul> <ul>
<li> <li>
@ -795,6 +858,9 @@ export default () => (
</ul> </ul>
</nav> </nav>
) )
}
export default Header
``` ```
#### Imperatively #### Imperatively
@ -804,7 +870,8 @@ Most prefetching needs are addressed by `<Link />`, but we also expose an impera
```jsx ```jsx
import { withRouter } from 'next/router' import { withRouter } from 'next/router'
export default withRouter(({ router }) => ( function MyLink({ router }) {
return (
<div> <div>
<a onClick={() => setTimeout(() => router.push('/dynamic'), 100)}> <a onClick={() => setTimeout(() => router.push('/dynamic'), 100)}>
A route transition will happen after 100ms A route transition will happen after 100ms
@ -813,6 +880,9 @@ export default withRouter(({ router }) => (
router.prefetch('/dynamic')} router.prefetch('/dynamic')}
</div> </div>
) )
}
export default withRouter(MyLink)
``` ```
The router instance should be only used inside the client side of your app though. In order to prevent any error regarding this subject, when rendering the Router on the server side, use the imperatively prefetch method in the `componentDidMount()` lifecycle method. The router instance should be only used inside the client side of your app though. In order to prevent any error regarding this subject, when rendering the Router on the server side, use the imperatively prefetch method in the `componentDidMount()` lifecycle method.
@ -1004,13 +1074,17 @@ import dynamic from 'next/dynamic'
const DynamicComponent = dynamic(() => import('../components/hello')) const DynamicComponent = dynamic(() => import('../components/hello'))
export default () => ( function Home() {
return (
<div> <div>
<Header /> <Header />
<DynamicComponent /> <DynamicComponent />
<p>HOME PAGE is here!</p> <p>HOME PAGE is here!</p>
</div> </div>
) )
}
export default Home
``` ```
#### 2. With Custom Loading Component #### 2. With Custom Loading Component
@ -1022,13 +1096,17 @@ const DynamicComponentWithCustomLoading = dynamic(() => import('../components/he
loading: () => <p>...</p> loading: () => <p>...</p>
}) })
export default () => ( function Home() {
return (
<div> <div>
<Header /> <Header />
<DynamicComponentWithCustomLoading /> <DynamicComponentWithCustomLoading />
<p>HOME PAGE is here!</p> <p>HOME PAGE is here!</p>
</div> </div>
) )
}
export default Home
``` ```
#### 3. With No SSR #### 3. With No SSR
@ -1040,13 +1118,17 @@ const DynamicComponentWithNoSSR = dynamic(() => import('../components/hello3'),
ssr: false ssr: false
}) })
export default () => ( function Home() {
return (
<div> <div>
<Header /> <Header />
<DynamicComponentWithNoSSR /> <DynamicComponentWithNoSSR />
<p>HOME PAGE is here!</p> <p>HOME PAGE is here!</p>
</div> </div>
) )
}
export default Home
``` ```
#### 4. With Multiple Modules At Once #### 4. With Multiple Modules At Once
@ -1073,7 +1155,11 @@ const HelloBundle = dynamic({
</div> </div>
}) })
export default () => <HelloBundle title="Dynamic Bundle" /> function DynamicBundle() {
return <HelloBundle title="Dynamic Bundle" />
}
export default DynamicBundle
``` ```
### Custom `<App>` ### Custom `<App>`
@ -1101,7 +1187,7 @@ To override, create the `./pages/_app.js` file and override the App class as sho
import React from 'react' import React from 'react'
import App, { Container } from 'next/app' import App, { Container } from 'next/app'
export default class MyApp extends App { class MyApp extends App {
static async getInitialProps({ Component, ctx }) { static async getInitialProps({ Component, ctx }) {
let pageProps = {} let pageProps = {}
@ -1122,6 +1208,8 @@ export default class MyApp extends App {
) )
} }
} }
export default MyApp
``` ```
### Custom `<Document>` ### Custom `<Document>`
@ -1149,7 +1237,7 @@ Pages in `Next.js` skip the definition of the surrounding document's markup. For
// ./pages/_document.js // ./pages/_document.js
import Document, { Head, Main, NextScript } from 'next/document' import Document, { Head, Main, NextScript } from 'next/document'
export default class MyDocument extends Document { class MyDocument extends Document {
static async getInitialProps(ctx) { static async getInitialProps(ctx) {
const initialProps = await Document.getInitialProps(ctx) const initialProps = await Document.getInitialProps(ctx)
return { ...initialProps } return { ...initialProps }
@ -1169,6 +1257,8 @@ export default class MyDocument extends Document {
) )
} }
} }
export default MyDocument
``` ```
All of `<Head />`, `<Main />` and `<NextScript />` are required for page to be properly rendered. All of `<Head />`, `<Main />` and `<NextScript />` are required for page to be properly rendered.
@ -1188,7 +1278,7 @@ that need to wrap the application to properly work with server-rendering. 🚧
```js ```js
import Document from 'next/document' import Document from 'next/document'
export default class MyDocument extends Document { class MyDocument extends Document {
static async getInitialProps(ctx) { static async getInitialProps(ctx) {
const originalRenderPage = ctx.renderPage const originalRenderPage = ctx.renderPage
@ -1205,6 +1295,8 @@ export default class MyDocument extends Document {
return initialProps return initialProps
} }
} }
export default MyDocument
``` ```
### Custom error handling ### Custom error handling
@ -1216,7 +1308,7 @@ export default class MyDocument extends Document {
```jsx ```jsx
import React from 'react' import React from 'react'
export default class Error extends React.Component { class Error extends React.Component {
static getInitialProps({ res, err }) { static getInitialProps({ res, err }) {
const statusCode = res ? res.statusCode : err ? err.statusCode : null; const statusCode = res ? res.statusCode : err ? err.statusCode : null;
return { statusCode } return { statusCode }
@ -1232,6 +1324,8 @@ export default class Error extends React.Component {
) )
} }
} }
export default Error
``` ```
### Reusing the built-in error page ### Reusing the built-in error page
@ -1243,7 +1337,7 @@ import React from 'react'
import Error from 'next/error' import Error from 'next/error'
import fetch from 'isomorphic-unfetch' import fetch from 'isomorphic-unfetch'
export default class Page extends React.Component { class Page extends React.Component {
static async getInitialProps() { static async getInitialProps() {
const res = await fetch('https://api.github.com/repos/zeit/next.js') const res = await fetch('https://api.github.com/repos/zeit/next.js')
const errorCode = res.statusCode > 200 ? res.statusCode : false const errorCode = res.statusCode > 200 ? res.statusCode : false
@ -1264,6 +1358,8 @@ export default class Page extends React.Component {
) )
} }
} }
export default Page
``` ```
> If you have created a custom error page you have to import your own `_error` component from `./_error` instead of `next/error` > If you have created a custom error page you have to import your own `_error` component from `./_error` instead of `next/error`
@ -1577,9 +1673,11 @@ This will allow you to use `process.env.customKey` in your code. For example:
```jsx ```jsx
// pages/index.js // pages/index.js
export default function Index() { function Index() {
return <h1>The value of customEnv is: {process.env.customEnv}</h1> return <h1>The value of customEnv is: {process.env.customEnv}</h1>
} }
export default Index
``` ```
#### Runtime configuration #### Runtime configuration
@ -1617,9 +1715,15 @@ const {serverRuntimeConfig, publicRuntimeConfig} = getConfig()
console.log(serverRuntimeConfig.mySecret) // Will only be available on the server side console.log(serverRuntimeConfig.mySecret) // Will only be available on the server side
console.log(publicRuntimeConfig.staticFolder) // Will be available on both server and client console.log(publicRuntimeConfig.staticFolder) // Will be available on both server and client
export default () => <div> function MyImage() {
return (
<div>
<img src={`${publicRuntimeConfig.staticFolder}/logo.png`} alt="logo" /> <img src={`${publicRuntimeConfig.staticFolder}/logo.png`} alt="logo" />
</div> </div>
)
}
export default MyImage
``` ```
### Starting the server on alternative hostname ### Starting the server on alternative hostname