Foros del Web » Programando para Internet » Node.js »

Separar codigo en archivos

Estas en el tema de Separar codigo en archivos en el foro de Node.js en Foros del Web. Gente me interesaria aprender a ordenar el codigo por archivos, es decir un archivo con nombre server.js que tendria la configuracion de ruteo y demas, ...
  #1 (permalink)  
Antiguo 12/02/2015, 12:22
 
Fecha de Ingreso: noviembre-2011
Mensajes: 69
Antigüedad: 13 años, 1 mes
Puntos: 0
Separar codigo en archivos

Gente me interesaria aprender a ordenar el codigo por archivos, es decir un archivo con nombre server.js que tendria la configuracion de ruteo y demas, config.js que contendría la conexion a la base de datos, consultas.js que tendria las consultas mysql es posible hacerlo con Node.js y express?, ademas utilizo plantillas .ejs.

Código PHP:

var express  = require('express'),
    
path     = require('path'),
    
bodyParser = require('body-parser'),
    
app express(),
    
expressValidator = require('express-validator');


/*Set EJS template Engine*/
app.set('views','./views');
app.set('view engine','ejs');

//app.set('view cache', false);


app.use(express.static(path.join(__dirname'public')));
app.use(bodyParser.urlencoded({ extendedtrue })); //support x-www-form-urlencoded
app.use(bodyParser.json());
app.use(expressValidator());

/*MySql connection*/
var connection  = require('express-myconnection'),
    
mysql = require('mysql');

app.use(
    
connection(mysql,{
        
host     'localhost',
        
user     'root',
        
password '',
        
database 'test',
        
debug    false //set true if you wanna see debug logger
    
},'request')

);



// index page 
app.get('/', function(reqres){
    
res.render("index");
});


//RESTful route
var router express.Router();

/*------------------------------------------------------
*  This is router middleware,invoked everytime
*  we hit url /api and anything after /api
*  like /api/user , /api/user/7
*  we can use this for doing validation,authetication
*  for every route started with /api
--------------------------------------------------------*/
router.use(function(reqresnext) {
    
console.log(req.methodreq.url);
    
next();
});

var 
curut router.route('/user');
//show the CRUD interface | GET
curut.get(function(req,res){
    
req.getConnection(function(err,conn){
        if (
err) return next("Cannot Connect");
        var 
query conn.query('SELECT * FROM t_user',function(err,rows){
            if(
err){
                
console.log(err);
                return 
next("Mysql error, check your query");
            }
            
res.render('user',{title:"Pagina de Usuarios",data:rows});
         });
    });
});

//post data to DB | POST
curut.post(function(req,res){

    
//validation
    
req.assert('name','Name is required').notEmpty();
    
req.assert('email','A valid email is required').isEmail();
    
req.assert('password','Enter a password 6 - 20').len(6,20);

    var 
errors req.validationErrors();
    if(
errors){
        
res.status(422).json(errors);
        return;
    }

    
//get data
    
var data = {
        
name:req.body.name,
        
email:req.body.email,
        
password:req.body.password
     
};

    
//inserting into mysql
    
req.getConnection(function (errconn){
        if (
err) return next("Cannot Connect");
        var 
query conn.query("INSERT INTO t_user set ? ",data, function(errrows){
           if(
err){
                
console.log(err);
                return 
next("Mysql error, check your query");
           }
          
res.sendStatus(200);
        });
     });
});


//now for Single route (GET,DELETE,PUT)
var curut2 router.route('/user/:user_id');

/*------------------------------------------------------
route.all is extremely useful. you can use it to do
stuffs for specific routes. for example you need to do
a validation everytime route /api/user/:user_id it hit.

remove curut2.all() if you dont want it
------------------------------------------------------*/
curut2.all(function(req,res,next){
    
console.log("You need to smth about curut2 Route ? Do it here");
    
console.log(req.params);
    
next();
});

//get data to update
curut2.get(function(req,res,next){
    var 
user_id req.params.user_id;
    
req.getConnection(function(err,conn){
        if (
err) return next("Cannot Connect");
        var 
query conn.query("SELECT * FROM t_user WHERE user_id = ? ",[user_id],function(err,rows){
            if(
err){
                
console.log(err);
                return 
next("Mysql error, check your query");
            }

            
//if user not found
            
if(rows.length 1)
                return 
res.send("User Not found");
            
res.render('edit',{title:"Edit user",data:rows});
        });
    });
});

//update data
curut2.put(function(req,res){
    var 
user_id req.params.user_id;

    
//validation
    
req.assert('name','Name is required').notEmpty();
    
req.assert('email','A valid email is required').isEmail();
    
req.assert('password','Enter a password 6 - 20').len(6,20);

    var 
errors req.validationErrors();
    if(
errors){
        
res.status(422).json(errors);
        return;
    }

    
//get data
    
var data = {
        
name:req.body.name,
        
email:req.body.email,
        
password:req.body.password
     
};

    
//inserting into mysql
    
req.getConnection(function (errconn){
        if (
err) return next("Cannot Connect");
        var 
query conn.query("UPDATE t_user set ? WHERE user_id = ? ",[data,user_id], function(errrows){
           if(
err){
                
console.log(err);
                return 
next("Mysql error, check your query");
           }
          
res.sendStatus(200);
        });
     });
});

//delete data
curut2.delete(function(req,res){
    var 
user_id req.params.user_id;
     
req.getConnection(function (errconn) {
        if (
err) return next("Cannot Connect");
        var 
query conn.query("DELETE FROM t_user  WHERE user_id = ? ",[user_id], function(errrows){
             if(
err){
                
console.log(err);
                return 
next("Mysql error, check your query");
             }
             
res.sendStatus(200);
        });
        
//console.log(query.sql);
     
});
});

//now we need to apply our router here
app.use('/api'router);

//start Server
var server app.listen(3000,function(){

   
console.log("Listening to port %s",server.address().port);

}); 

{
"name": "rest-crud",
"description": "REST CRUD Example Node.js & Mysql",
"version": "0.0.1",
"private": true,
"main": "server.js",
"dependencies": {
"body-parser": "1.9.0",
"ejs": "^1.0.0",
"express": "4.9.5",
"express-myconnection": "*",
"express-validator": "^2.6.0",
"mysql": "*"
}
}
  #2 (permalink)  
Antiguo 12/02/2015, 12:24
Avatar de Carlangueitor
Moderador ლ(ಠ益ಠლ)
 
Fecha de Ingreso: marzo-2008
Ubicación: México
Mensajes: 10.037
Antigüedad: 16 años, 9 meses
Puntos: 1329
Respuesta: Separar codigo en archivos

Y exactamente ¿cuál es tu problema?

Saludos
__________________
Grupo Telegram Docker en Español
  #3 (permalink)  
Antiguo 12/02/2015, 13:32
 
Fecha de Ingreso: noviembre-2011
Mensajes: 69
Antigüedad: 13 años, 1 mes
Puntos: 0
Respuesta: Separar codigo en archivos

Cita:
Iniciado por Carlangueitor Ver Mensaje
Y exactamente ¿cuál es tu problema?

Saludos
No se como hacerlo jaja, cada no se como incluir los archivos, y todo lo que pruebo me tira error.
  #4 (permalink)  
Antiguo 12/02/2015, 13:36
Avatar de Carlangueitor
Moderador ლ(ಠ益ಠლ)
 
Fecha de Ingreso: marzo-2008
Ubicación: México
Mensajes: 10.037
Antigüedad: 16 años, 9 meses
Puntos: 1329
Respuesta: Separar codigo en archivos

Por ejemplo:

Código Javascript:
Ver original
  1. // object.js
  2. module.exports = {
  3.   foo: 'bar'
  4. };
  5.  
  6. // main.js
  7. var object = require('./object');
  8. console.log(object.foo);

¿Eso es lo que no sabes hacer?

Saludos
__________________
Grupo Telegram Docker en Español
  #5 (permalink)  
Antiguo 12/02/2015, 22:04
Avatar de jsstoni  
Fecha de Ingreso: enero-2015
Ubicación: Maracaibo
Mensajes: 82
Antigüedad: 10 años
Puntos: 4
Respuesta: Separar codigo en archivos

conjunto a lo que menciona Carlangueitor busca como crear modulos para nodejs.
__________________
Desarrollo web Front End Realtime NodeJs

Etiquetas: Ninguno
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 17:19.