Making Websites

with JavaScript

 

Katja Durrani

@kdurrani

mail@kdurrani.co.uk

Women Who Code

Bristol

27 Jan 2015

 

Key Features

  • JavaScript outside the browser
  • Contains a library for creating a web server
  • 'Single-threaded, event-based, non-blocking I/O'
  • Suited for real-time applications
  • Modular (CommonJS style)
  • Can be extended via npm package manager

"A development platform built on top of Google's V8 JavaScript virtual machine"

What is NodeJS?

What Node is used for

  • Building APIs
  • Real-time web applications, streaming
  • Building command-line tools
  • Hard-ware hacking

Node is popular

About 90 NodeSchools world-wide!

  • Setting up a server
  • Routing
  • Providing APIs

Main uses for Express

There are some alternative frameworks (Hapi, Koa), but so far Express is the most widely used

The "Hello World" of Node and Express:

Writing a server

var express = require('express')
var app = express()

app.get('/', function (req, res) {
  res.send('Hello World!')
})

var server = app.listen(3000, function () {
  var host = server.address().address
  var port = server.address().port
  console.log('Example app listening at http://%s:%s', host, port)
})
var http = require('http'); 

http.createServer(function (req, res) { 
    res.writeHead(200, {'Content-Type': 'text/plain'}); 
    res.end('Hello World\n'); 
}).listen(8124, "127.0.0.1"); 

console.log('Server running at http://127.0.0.1:8124/');

Node

Express

JS App Workflow Considerations

Structure

Sub-directories for static files, views, routes, models etc.

Dependency Management

Usually via package manager (e.g. npm, bower, composer)

For npm:  Dependencies listed in package.json file

                    

 



npm install         // installs dependencies listed in package.json

npm install <module> --save  // installs new package, saves reference in package.json

JS App Workflow ctd.

Task Automation

Grunt, Gulp

Modularisation

Node uses  CommonJS syntax                  

 

var React = require('react');

var App = {
[...]
}

module.exports = App

You can write node-style modules for the browser, using tools like browserify which compile them for that use

Hosting

You might have to add code to your app for it to run on specific platforms (e.g. OpenShift, AWS, Heroku)

Looking at an example

Real-time Polls App built on MEAN stack

Key Features

  • Markup and display logic are combined inside nestable components
  • 'Virtual DOM and synthetic events'
  • High performance
  • One-way reactive data flow
  • Re-renders whole component on every change
  • JSX preprocessor lets you use HTML-like syntax inside JS

"A JavaScript library for building user interfaces -

the V in MVC"

What is ReactJS?

Example of React Component (before and after compilation to JS)

Playing with ReactJS

Click to get through to the sites

Thank you!

Making websites with JavaScript

By Katja Durrani

Making websites with JavaScript

  • 1,184