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

Add a preact example. (#543)

* Add preact example.

* Update .babelrc
This commit is contained in:
Arunoda Susiripala 2016-12-28 00:28:10 +05:30 committed by Guillermo Rauch
parent de7801df2d
commit 1ba315fcc1
6 changed files with 79 additions and 0 deletions

View file

@ -0,0 +1,6 @@
{
"presets": [
"es2015",
"react"
]
}

View file

@ -0,0 +1,33 @@
# Hello World example
## How to use
Download the example (or clone the repo)[https://github.com/zeit/next.js.git]:
```bash
curl https://codeload.github.com/zeit/next.js/tar.gz/master | tar -xz --strip=2 next.js-master/examples/using-preact
cd using-preact
```
Install it and run:
```bash
npm install
npm run dev
```
Deploy it to the cloud with [now](https://zeit.co/now) ([download](https://zeit.co/download))
```bash
now
```
## The idea behind the example
This example uses [Preact](https://github.com/developit/preact) instead of React. It's a React like UI framework which fast and small. Here we've customized Next.js to use Preact instead of React.
Here's how we did it:
* Create `.babelrc` file with es2015 and react presets. This allow us to get rid of the hard coded React dependency for core Next.js modules.
* Use `next.config.js` to customize our webpack config to support [preact-compat](https://github.com/developit/preact-compat)

View file

@ -0,0 +1,9 @@
module.exports = {
webpack: function (config) {
config.resolve.alias = {
'react': 'preact-compat',
'react-dom': 'preact-compat'
}
return config
}
}

View file

@ -0,0 +1,20 @@
{
"name": "hello-world",
"version": "1.0.0",
"scripts": {
"dev": "next",
"build": "next build",
"start": "next start"
},
"dependencies": {
"next": "^2.0.0-beta",
"preact": "^7.1.0",
"preact-compat": "^3.9.4"
},
"author": "",
"license": "ISC",
"devDependencies": {
"babel-preset-es2015": "^6.18.0",
"babel-preset-react": "^6.16.0"
}
}

View file

@ -0,0 +1,5 @@
import React from 'react'
export default () => (
<div>About us</div>
)

View file

@ -0,0 +1,6 @@
import React from 'react'
import Link from 'next/link'
export default () => (
<div>Hello World. <Link href='/about'>About</Link></div>
)