Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imranhsayed/next-js-app
:globe_with_meridians: Next JS Application Demo
https://github.com/imranhsayed/next-js-app
express javascript nextjs nodejs pwa pwa-apps react reactjs service-workers
Last synced: 2 months ago
JSON representation
:globe_with_meridians: Next JS Application Demo
- Host: GitHub
- URL: https://github.com/imranhsayed/next-js-app
- Owner: imranhsayed
- Created: 2019-05-26T08:27:00.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-10T17:30:00.000Z (about 2 years ago)
- Last Synced: 2024-11-01T19:52:39.002Z (3 months ago)
- Topics: express, javascript, nextjs, nodejs, pwa, pwa-apps, react, reactjs, service-workers
- Language: JavaScript
- Size: 115 KB
- Stars: 50
- Watchers: 3
- Forks: 41
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Next JS Application
# Full Series Tutorial
https://codeytek.com/course/next-js-tutorials-for-beginners/## Description :clipboard:
> A Next JS Application Demo.## Installation :wrench:
1. Clone this repo by running `git clone https://github.com/imranhsayed/next-js-app`
2. `cd next-js-app`
3. `npm install`
4. `npm run dev`## Useful Links: :link:
1. [Next JS Docs](https://nextjs.org/learn/basics/getting-started/setup)
## Instructions :point_right:
## Branches Information :point_right:
1. [simple-nextjs-app](https://github.com/imranhsayed/next-js-app/tree/simple-nextjs-app) Simple next js app
2. [express-with-next)](https://github.com/imranhsayed/next-js-app/tree/express-with-next)) Simple next js app with custom express server
3. [express-with-next-ssr)](https://github.com/imranhsayed/next-js-app/tree/express-with-next-ssr)) Custom end point by creating express server, and displaying clean URL for single post ( `'/post/slug' instead of '/post?id=22'` )
3. [shared-component-navigation](https://github.com/imranhsayed/next-js-app/tree/shared-component-navigation) Example to show navigation and Creating Layout Component that can be shared between multiple component.
4. [dynamic-page-query-string](https://github.com/imranhsayed/next-js-app/tree/dynamic-page-query-string) Example to create dynamic post pages by extracting query string from url using `withRouter`
5. [route-masking](https://github.com/imranhsayed/next-js-app/tree/route-masking) Example to show a different URL on the browser than the actual URL that your app sees by adding "as" props to the link.## [Custom Express Configuration with next js](https://github.com/imranhsayed/next-js-app/tree/express-with-next)
```ruby
const express = require( 'express' );
const next = require( 'next' );const port = 3000;
const dev = process.env.NODE_ENV !== 'production';
const app = next( { dev } );
const handle = app.getRequestHandler();/**
* app (next js ) will prepare our server with express, and then,
* wrap express application inside next
*
*/
app.prepare()
.then( () => {
const server = express();/**
* This will override the default '/about' next js route and when user goes to '/about'
* it will serve index.js because route '/' which we are rendering in app.render() belongs to index.js
*/
server.get( '/about', ( req, res ) => {
return app.render( req, res, '/' );
} );/**
* Wrapping express app inside next will allow us to create routes by using
* express js function inside of the next js build
*
* '*' means all routes which are not explicit , use this route for them.
*/
server.get( '*', ( req, res ) => {
return handle( req, res );
} );server.listen( port, ( err ) => {
if ( err ) {
throw err;
}
console.warn( `Ready on http://localhost:${port}` );
} );
} );
```## Common Commands :computer:
1. `dev` Starts local development server at [http://localhost:3000](http://localhost:3000)
2. `build` Runs build
3. `start` Runs next js server## Built With :zap:
1. Node
2. Express
3. React
4. Next JS
5. Webpack
6. Babel# Useful Blogs
1. [Headless WordPress with Next JS](https://medium.com/kata-engineering/headless-wordpress-next-js-what-we-learned-c10abdf80f6a)
# Useful Links
1. [GraphQL API Plugin for WordPress](https://github.com/wp-graphql/wp-graphql)
## Author :bust_in_silhouette:
* **[Imran Sayed](https://codeytek.com)**
## License
[![License](http://img.shields.io/:license-mit-blue.svg?style=flat-square)](http://badges.mit-license.org)
- **[MIT license](http://opensource.org/licenses/mit-license.php)**