docs | ||
lib | ||
test | ||
.babelrc | ||
.codeclimate.yml | ||
.eslintignore | ||
.eslintrc | ||
.gitignore | ||
.npmignore | ||
.travis.yml | ||
bower.json | ||
frontexpress.js | ||
frontexpress.min.js | ||
frontexpress.min.js.map | ||
index.js | ||
LICENSE | ||
package.json | ||
README.md | ||
rollup.config.dev.js | ||
rollup.config.prod.js |
Frontexpress manages routes in browser like ExpressJS does on Node.
Same language same API on all the stack.
Code the front-end logic with the same style than on the back-end with express
import frontexpress from 'frontexpress';
// Front-end application
const app = frontexpress();
// navigation on path /page1
app.get('/page1', (req, res) => {
document.querySelector('.content').innerHTML = `<h1>Page 1 content</h1>`;
});
// navigation on path /page2
app.get('/page2', (req, res) => {
document.querySelector('.content').innerHTML = `<h1>Page 2 content</h1>`;
});
// start front-end application
app.listen(() => {
// on DOM ready
});
Installation
From npm repository
$ npm install frontexpress
From bower repository
$ bower install frontexpress
From CDN
On jsDelivr
Quick Start
The quickest way to get started with frontexpress is to clone the frontexpress-demo repository.
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
Navigation path and frontexpress routing
Disclaimer
In this first version of frontexpress, the API is not completely the mirror of the expressjs one.
There are some missing methods. Currently, the use, get, post... methods having a middleware array as parameter are not available. The string pattern to define route paths is not yet implemented.
Obviously, the objective is to have the same API as expressjs when the methods make sense browser side.
Basic routing
Listen navigation (GET request) on path /hello:
app.get('/hello', (req, res) => {
window.alert('Hello World');
});
Listen a POST request on path /item:
app.post('/item', (req, res) => {
window.alert('Got a POST request at /item');
});
Routing based on RegExp
Listen navigation on paths which start with /api/:
app.get(/^api\//, (req, res) => {
console.log(`api was requested ${req.uri}`);
});
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);
API
Method | Short description | |
---|---|---|
Frontexpress | ||
frontexpress() | Creates an instance of application | |
frontexpress.Router() | Creates a Router object | |
frontexpress.Middleware() | Creates a Middleware object | |
Application | ||
set(setting, value) | Assigns a setting | |
listen(callback) | Starts the application | |
route(uri) | Gets a Router initialized with a root path | |
use(uri, middleware) | Sets a middleware | |
get(uri, middleware) | Applies a middleware on given path for a GET request | |
post(uri, middleware) | Applies a middleware on given path for a POST request | |
put(uri, middleware) | Applies a middleware on given path for a PUT request | |
delete(uri, middleware) | Applies a middleware on given path for a DELETE request | |
httpGet(request, success, failure) | Invokes a GET ajax request | |
httpPost(request, success, failure) | Invokes a POST ajax request | |
httpPut(request, success, failure) | Invokes a PUT ajax request | |
httpDelete(request, success, failure) | Invokes a DELETE ajax request | |
Router | ||
use(middleware) | Sets a middleware | |
all(middleware) | Sets a middleware on all HTTP method requests | |
get(uri, middleware) | Applies a middleware on given path for a GET request | |
post(uri, middleware) | Applies a middleware on given path for a POST request | |
put(uri, middleware) | Applies a middleware on given path for a PUT request | |
delete(uri, middleware) | Applies a middleware on given path for a DELETE request | |
Middleware | ||
entered(request) | Invoked by the app before an ajax request is sent | |
exited(request) | Invoked by the app before a new ajax request is sent | |
updated(request, response) | Invoked by the app after an ajax request has responded | |
failed(request, response) | Invoked by the app after an ajax request has failed | |
next() | Allows to break the middleware chain execution |
middleware function
After registering a middleware function, the application invokes it with these parameters:
(request, response, next) => {
next();
}
request: Object
, the ajax request information sent by the app
response: Object
, the response of request
next: Function
, the next()
function to call to not break the middleware execution chain
request object
{
method,
uri,
headers,
data,
history: {
state,
title,
uri
}
}
method: String
, HTTP methods 'GET', 'POST'...
uri: String
, path
headers: Object
, custom HTTP headers
data: Object
, data attached to the request
history: Object
, object with properties state, title and uri
If the history object is set, it will activate the browser history management. See browser pushState() method for more information about state, title, and uri (url).
uri and history.uri can be different.
response object
{
status,
statusText,
responseText,
errorThrown,
errors
}
status: Number
, HTTP status 200, 404, 401, 500...
statusText: String
responseText: String
response content
errorThrown: Object
exception thrown (if request fails)
errors: String
error description (if request fails)