Skip to content

Latest commit

 

History

History
224 lines (168 loc) · 5.39 KB

README.md

File metadata and controls

224 lines (168 loc) · 5.39 KB

CoderDojo - Start Node - Create a social network

This is an introduction to server side programming in Node.js and was created for CoderDojo members. The aim of this session is to create a social network in 2 hours! Which we can then launch and sell for billions

Step 1 Install Node

Install Node from http://nodejs.org

Step 2 Setup the project

Create the project folder

mkdir coderdojo-start-node

Now create a folder called public, this is the folder where you will add the html, css and javascript code.

cd coderdojo-start-node
mkdir public

Install express

npm is Node Package Manager allows you to install Node Packages, to run a web server we are going to use a node package called express will enable us to create a server easily that can accept web requests.

Now run

npm install express

Turn it into a social website and install socket.io

Socket.io is a technology that allows browsers to easily communicate with the server over streams.

Now run

npm install socket.io

Now lets create our Node.js file

Now in the home directory coderdojo-start-node save a new file called app.js. Inside app.js add the following code

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

// Bring up a HTTP Server on port 3000.
var server = app.listen(3000, function () {
    console.log('Listening on port %d', server.address().port);
});
var io = require('socket.io')(server);

app.get('/coderdojo', function(req, res){
    res.send('Be cool');
});

This code creates your first server and first http call

Run your code

From inside directory coderdojo-start-node open a command terminal and run

node app

We are running app because the file is called app.js

You should see the following output from this command

$ node app
Listening on port 3000

This is tell you that a server has started on your machine at port 3000

You can stop the server at any time by running CTRL+C

Open your browser

Navigate to http://localhost:3000

You get an error right! But remember in your code you told the server to reference /coderdojo so you need to navigate to http://localhost:3000/coderdojo

Now see what happens

We now need update app.js to read your html code from the public folder

Update app.js with the following code

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

// Bring up a HTTP Server on port 3000.
var server = app.listen(3000, function () {
    console.log('Listening on port %d', server.address().port);
});
var io = require('socket.io')(server);

app.get('/coderdojo', function(req, res){
    res.send('Be cool');
});

// Serve the public directory as root.
app.use(express.static(path.join(__dirname, 'public')));

// Wait for connections.
io.on('connection', function (socket) {
    // when a connection emits a 'chat' signal.
    socket.on('chat', function (data) {
        // broadcast their message to all connections.
        socket.broadcast.emit('chat', data);
    });
});

Now add your html and css code

<html>
<head>
    <style rel="stylesheet">
        body {
            background: black;
            color: white;
            font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
        }

        h1 {
            color: pink;
        }

        .input {
            color: gray;
            font-size: 15px;
            margin: 5px;
            vertical-align: top;
            width: 500px;
        }

        div.inputDiv {
            padding-left: 30px;
            width: 100%;
            color: pink;
        }

        button {
            background: green;
            padding: 10px;
            color: white;
            font-size: 12px;
            border: 1px solid white;
        }

        span.chatname {
            color: red;
            font-size: 14px;
        }

        span.message {
            color: gray;
            font-size: 18px;
        }
    </style>
</head>
<script src="jquery.js"></script>
<script src="/socket.io/socket.io.js"></script>
<script>
    // Connect to the socket server.
    var socket = io.connect('http://localhost:3000');

    // On receiving a 'chat' broadcast display it on screen.
    socket.on('chat', function (chatData) {
        displayChat(chatData.name, chatData.chat);
    });

    // Emit socket message containing name and message.
    function send() {
        var name = $("#name").val();
        var chat = $("#chat").val();
        socket.emit('chat', { name: name, chat: chat });
        displayChat(name, chat);
    }

    // Append newly received messages to the DOM.
    function displayChat(from, message) {
        $("#socialchat").prepend("<div id='chatmessage'><span class='chatname'>" + from + " says "
                + " </span><br/> "
                + "<span class='message'>" + message + "</span>"
                + "</div>");
    }
</script>
<body>
<h1>CoderDojo Social Network</h1>

<div class="inputDiv">
    <input id="name" type="text" placeholder="name" class="input">
</div>
<div class="inputDiv">
    <textarea rows="5" cols="50" id="chat" placeholder="chat here" class="input"></textarea>
</div>
<div class="buttons">
    <button id="send" onclick="send()">Send</button>
</div>
<hr/>
<h2>Social Chat</h2>

<div id="socialchat"></div>
</body>
</html>

Now open your browser and navigate to http://localhost:3000