Go to file
2017-06-22 21:22:12 +02:00
docs fixed issues #5 #6 2017-06-22 21:17:18 +02:00
lib fixed issues #5 #6 2017-06-22 21:17:18 +02:00
test fixed issues #5 #6 2017-06-22 21:17:18 +02:00
.babelrc exposed frontexpress in the browser global context #2 2016-09-08 23:19:07 +02:00
.codeclimate.yml added codeclimate config 2017-01-13 14:47:30 +01:00
.eslintignore added source map and made lib directory visible for bower deployment #3 2016-09-12 00:40:45 +02:00
.eslintrc made eslint stricter - added unit tests to cover sample in README 2016-07-10 00:58:03 +02:00
.gitignore Added webpack to generate frontexpress.min.js for bower deployment #2 2016-09-08 21:50:01 +02:00
.travis.yml optimized lib size - changed frontexpress.Middleware now it returns a class and not an instance anymore 2017-01-13 14:23:15 +01:00
bower.json replaced webpack by rollup to reduce browser bundle size (-3kb) 2016-09-15 19:16:42 +02:00
frontexpress.js fixed issues #5 #6 2017-06-22 21:17:18 +02:00
frontexpress.min.js fixed issues #5 #6 2017-06-22 21:17:18 +02:00
frontexpress.min.js.map fixed issues #5 #6 2017-06-22 21:17:18 +02:00
gzipsize.js diet for reducing lib size 2017-01-14 15:02:50 +01:00
index.js exposed frontexpress in the browser global context #2 2016-09-08 23:19:07 +02:00
LICENSE Initial commit 2016-06-26 11:34:45 +02:00
package.json fixed issues #5 #6 2017-06-22 21:17:18 +02:00
README.md Update README.md 2017-06-22 21:22:12 +02:00
rollup.config.dev.js diet for reducing lib size 2017-01-14 15:02:50 +01:00
rollup.config.prod.js better support of es modules 2017-05-26 14:25:37 +02:00

frontexpress

Code the front-end like on the back-end with ExpressJS

frontexpress demo

Build Status Code Climate Coverage Status dependencies Size Shield

Installation

From npm repository

$ npm install frontexpress

From bower repository

$ bower install frontexpress

From CDN

On jsDelivr

Usage

import frontexpress from 'frontexpress';

// Front-end application
const app = frontexpress();

// front-end logic on navigation path "/page1"
app.get('/page1', (req, res) => {
    document.querySelector('.content').innerHTML = res.responseText;
});

// front-end logic on navigation path "/page2"
app.get('/page2', (req, res) => {
    document.querySelector('.content').innerHTML = res.responseText;
});

// start front-end application
app.listen();

Routes

Listen GET requests on path /hello:

app.get('/hello', (req, res) => {
  window.alert('Hello World');
});

Listen POST requests on path /item:

app.post('/item', (req, res) => {
  window.alert('Got a POST request at /item');
});

Listen GET requests on path starting with /api/:

app.get(/^api\//, (req, res) => {
  console.log(`api was requested ${req.uri}`);
});

Get parameters from path

app.get('/product/:id', (req, res) => {
  // if we have /product/42 then
  // req.params.id = 42
});
app.get('/user/:firstname?/:lastname', (req, res) => {
  // if we have /user/camel/aissani then
  // req.params.firstname = 'camel'
  // req.params.lastname = 'aissani'

  // if we have /user/aissani then
  // req.params.firstname = undefined
  // req.params.lastname = 'aissani'
});
app.get('/user/:id', (req, res) => {
  // if we have /user/1,2,3 then
  // req.params.id = [1,2,3]
});

Middleware object

The middleware object gives access to more hooks

  class MyMiddleware = new Middleware {
    entered(req) {
      // before request sent
    }

    updated(req, res) {
      // after request sent
      // res has the request response
      window.alert('Hello World');
    }

    exited(req) {
       // before a new request sent
    }

    failed(req, res) {
       // on request failed
    }

    next() {
       // for chaining
       return true;
    }

  }
  app.get('/hello', new MyMiddleware());

Chain handlers

You can provide multiple handlers functions on a navigation path. Invoking next() function allows to chain the handlers. At the opposite, when the next() method is not called the handler chain is stopped.

const h1 = (req, res, next) => { console.log('h1!'); next(); };
const h2 = (req, res, next) => { console.log('h2!') };
const h3 = (req, res, next) => { console.log('h3!'); next(); };

app.get('/example/a', h1);
app.get('/example/a', h2);
app.get('/example/a', h3);

On navigation on path /example/a, the browser console displays the following:

h1!
h2!

h3 is ignored because next() function was not invoked.

app.route()

You can create chainable route handlers for a route path by using app.route().

app.route('/book')
 .get((req, res) => { console.log('Get a random book') })
 .post((req, res) => { console.log('Add a book') })
 .put((req, res) => { console.log('Update the book') });

frontexpress.Router

Use the frontexpress.Router class to create modular, mountable route handlers.

Create a router file named birds.js:

import frontexpress from 'frontexpress';

const router = frontexpress.Router();

// specific middleware for this router
router.use((req, res, next) => {
  console.log(`Time: ${Date.now()}`);
  next();
});

// listen navigation on the home page
router.get('/', (req, res) => {
  document.querySelector('.content').innerHTML = '<p>Birds home page</p>';
});

// listen navigation on the about page
router.get('/about', (req, res) => {
  document.querySelector('.content').innerHTML = '<p>About birds</p>';
});

export default router;

Then, load the router module in the app:

import birds  from './birds';
...
app.use('/birds', birds);

More

API

Tests

Clone the git repository:

$ git clone git@github.com:camelaissani/frontexpress.git
$ cd frontexpress

Install the dependencies and run the test suite:

$ npm install
$ npm test

License

MIT