Node.js

App 제작 - 모듈의 활용

수업소개

모듈을 활용해서 템플릿 기능을 모듈화 해보겠습니다. 

 

 

 

강의

 

 

 

소스코드

변경사항

template.js

module.exports = {
  HTML:function(title, list, body, control){
    return `
    <!doctype html>
    <html>
    <head>
      <title>WEB1 - ${title}</title>
      <meta charset="utf-8">
    </head>
    <body>
      <h1><a href="/">WEB</a></h1>
      ${list}
      ${control}
      ${body}
    </body>
    </html>
    `;
  },list:function(filelist){
    var list = '<ul>';
    var i = 0;
    while(i < filelist.length){
      list = list + `<li><a href="/?id=${filelist[i]}">${filelist[i]}</a></li>`;
      i = i + 1;
    }
    list = list+'</ul>';
    return list;
  }
}

 

main.js

var http = require('http');
var fs = require('fs');
var url = require('url');
var qs = require('querystring');
var template = require('./lib/template.js');

var app = http.createServer(function(request,response){
    var _url = request.url;
    var queryData = url.parse(_url, true).query;
    var pathname = url.parse(_url, true).pathname;
    if(pathname === '/'){
      if(queryData.id === undefined){
        fs.readdir('./data', function(error, filelist){
          var title = 'Welcome';
          var description = 'Hello, Node.js';
          var list = template.list(filelist);
          var html = template.HTML(title, list,
            `<h2>${title}</h2>${description}`,
            `<a href="/create">create</a>`
          );
          response.writeHead(200);
          response.end(html);
        });
      } else {
        fs.readdir('./data', function(error, filelist){
          fs.readFile(`data/${queryData.id}`, 'utf8', function(err, description){
            var title = queryData.id;
            var list = template.list(filelist);
            var html = template.HTML(title, list,
              `<h2>${title}</h2>${description}`,
              ` <a href="/create">create</a>
                <a href="/update?id=${title}">update</a>
                <form action="delete_process" method="post">
                  <input type="hidden" name="id" value="${title}">
                  <input type="submit" value="delete">
                </form>`
            );
            response.writeHead(200);
            response.end(html);
          });
        });
      }
    } else if(pathname === '/create'){
      fs.readdir('./data', function(error, filelist){
        var title = 'WEB - create';
        var list = template.list(filelist);
        var html = template.HTML(title, list, `
          <form action="/create_process" method="post">
            <p><input type="text" name="title" placeholder="title"></p>
            <p>
              <textarea name="description" placeholder="description"></textarea>
            </p>
            <p>
              <input type="submit">
            </p>
          </form>
        `, '');
        response.writeHead(200);
        response.end(html);
      });
    } else if(pathname === '/create_process'){
      var body = '';
      request.on('data', function(data){
          body = body + data;
      });
      request.on('end', function(){
          var post = qs.parse(body);
          var title = post.title;
          var description = post.description;
          fs.writeFile(`data/${title}`, description, 'utf8', function(err){
            response.writeHead(302, {Location: `/?id=${title}`});
            response.end();
          })
      });
    } else if(pathname === '/update'){
      fs.readdir('./data', function(error, filelist){
        fs.readFile(`data/${queryData.id}`, 'utf8', function(err, description){
          var title = queryData.id;
          var list = template.list(filelist);
          var html = template.HTML(title, list,
            `
            <form action="/update_process" method="post">
              <input type="hidden" name="id" value="${title}">
              <p><input type="text" name="title" placeholder="title" value="${title}"></p>
              <p>
                <textarea name="description" placeholder="description">${description}</textarea>
              </p>
              <p>
                <input type="submit">
              </p>
            </form>
            `,
            `<a href="/create">create</a> <a href="/update?id=${title}">update</a>`
          );
          response.writeHead(200);
          response.end(html);
        });
      });
    } else if(pathname === '/update_process'){
      var body = '';
      request.on('data', function(data){
          body = body + data;
      });
      request.on('end', function(){
          var post = qs.parse(body);
          var id = post.id;
          var title = post.title;
          var description = post.description;
          fs.rename(`data/${id}`, `data/${title}`, function(error){
            fs.writeFile(`data/${title}`, description, 'utf8', function(err){
              response.writeHead(302, {Location: `/?id=${title}`});
              response.end();
            })
          });
      });
    } else if(pathname === '/delete_process'){
      var body = '';
      request.on('data', function(data){
          body = body + data;
      });
      request.on('end', function(){
          var post = qs.parse(body);
          var id = post.id;
          fs.unlink(`data/${id}`, function(error){
            response.writeHead(302, {Location: `/`});
            response.end();
          })
      });
    } else {
      response.writeHead(404);
      response.end('Not found');
    }
});
app.listen(3000);

 

댓글

댓글 본문
  1. Amousk
    좋은 강의 감사합니다.
  2. Katherine Roh
    완료 :)
  3. 김보미
    완료
  4. 바다의왕자
    완료
  5. 준바이
    지금 열고 있는 파일의 실제적인 구조를 다시 한번 점검해보시길 바래요~~
    그리구 커맨드라인 인터페이스 명령어에 대해 잠깐만 시간은 내서 공부하기실 권합니다.
    그러면 무조건 해결하실거에여~
  6. 준바이
    감사합니다
  7. 03.12 완료
  8. 스티븐잡숴
    흠..그러니까 ../는 최상위 디렉토리인 web2-nodejs를 뜻하고
    ./는 syntax 디렉토리가 되는거군요.

    그렇다면 그 아래 코드에 if 조건문을 보면

    fs.readdir('./data', func~~

    여기서 ./data는 왜 제대로 동작하는걸까요?
    syntax폴더는 data폴더의 상위폴더가 아닌데 말이죠...
    대화보기
    • 스티븐또잡숴
      ./는 현재 프로그램을 실행하려고 하는 위치, 즉 자신이 위치하고 있는 곳.
      ../는 가장 상위폴더 (루트) 를 가리킵니다.

      ./로 안돼시고 ../로 되시는거면 lib폴더가 main.js파일과 같은 폴더 안에 들어있지 않고,
      가장 바깥쪽에(상위폴더에) lib폴더가 놓여져 있어서 그런 것 같습니다.
      대화보기
      • eddylee123456
        완료
      • 스티븐잡숴
        var template = require('./lib/template.js')
        전 이렇게 하면 사이트에 연결할 수 없다고 뜨는데

        var template = require('xx/lib/template.js')
        요렇게 괄호안에 마침표 하나 더 찍으니까 잘 동작합니다. 아무런 문제 없어요.
        (x=마침표를 뜻합니다. 마침표 두개를 찍고 /를 입력하면 댓글이 안달아져요..ㅠㅠ)

        파일위치, 폴더위치 이고잉님이랑 똑같고
        원인을 몰라 코드내용도 걍 복사 붙여넣기로 100% 똑같이 했는데도 안됩니다.
        파일이름, 폴더이름 100%일치합니다.
        왜 안되는걸까요...허허
      • 임은정
        완료
      • ydkim108@gmail.com
        이 페이지에 좋아요,와 봤어요가 작동을 안하네요. 이전 몇 페이지도 그렇습니다.
      • codinginpain
        완료쓰
      • 강다리
        run
      • 쑤우
        수강완료. 감사합니다~
      • 얼그레이티
        if문 자체가 아니라 그 안에 들어있는 내용을 모듈화 해보라는 뜻인 것 같습니다.
        대화보기
        • 굼벵이
          완료
        • CronEB
          완료
        • YesterdayKite
          완료. 감사합니다!
        • 김형근
          if문을 모듈화 해보라고 하시는데, if문은 값으로서 사용될수 없기 때문에 변수에 넣지 못하지 않나요?
        • youngjin.lee
          completed
        • 이루
          완료
        • 허공
          190510 감사합니다.
        • 위준우
          완료
        • supernet
          감사합니다.
        • 권문수
          감사합니다^^ 모듈로써 코드의 복잡성을 더 줄일수 있게되었어요
        • 지미츄
          감사합니다 ! ㅎㅎ
        • 전에 만들었던 colors.js 파일은 이제 이용하지않나요?
          nodejs로 넘어오니 실행도 안되네요
        • jo_onc
          와, 이런 중요한 강의까지 해주시네요~
          감사합니다~
        • 삼고잉
          첫번째 훑기
        • Gimme_Gsuit
          너무 감사합니다. 거의다 끝나가네요. 화팅들 입니다.
        • moon
          감사합니다.
        • Seo Yun Seok Tudoistube
          node.js 는 많이 쓸텐데 왜 많이 안볼까 생각해보면, 공부할 여유마저 힘들어서 많이 못보는걸까 걱정됩니다.
          우리나라 시장이 점점 갈라파고스처럼 쓰던 기술을 쓰는데 머무를까 걱정입니다.
          감사합니다!
        버전 관리
        egoing
        현재 버전
        선택 버전
        graphittie 자세히 보기