node.js + CoffeeScript + Socket.IO + jQuery Mobile

서버/클라이언트 스크립트 코드 합쳐서 100줄이 안 되는 간단한 채팅 프로그램입니다.

npm install
npm start


<<< package.json >>>
{
    "name": "mobile_chat",
    "version": "1.0.0",
    "description": "Mobile chatting",
    "main": "./app.js",
    "dependencies": {
        "express": ">= 2.5",
        "socket.io": ">= 0.9.2"
    },
    "scripts": {
        "start": "forever start -c coffee app.coffee",
        "stop": "forever stop -c coffee app.coffee"
    }
}


<<< app.coffee >>>
express = require 'express'

app = express.createServer()

app.configure ->
  app.use express.static(__dirname + '/public')

app.get '/', (req, res) ->
  res.sendfile(__dirname + '/views/index.html')

io = require('socket.io').listen(app)

io.sockets.on 'connection', (socket) ->
  console.log '* CONNECT'

  socket.on 'enter', (data) ->
    username = data.username.trim()
    if username
      console.log "* ENTER: #{username}"
      socket.username = username
      socket.emit 'enter'
      io.sockets.emit 'talk',
        message: "[ENTER] #{username}"

  socket.on 'leave', (data) ->
    console.log "* LEAVE: #{socket.username}"
    socket.broadcast.emit 'talk',
      message: "[LEAVE] #{socket.username}"
    delete socket.username

  socket.on 'talk', (data) ->
    console.log "* TALK: #{data.message}"
    io.sockets.emit 'talk',
      message: "#{socket.username}: #{data.message}"

  socket.on 'disconnect', (data) ->
    console.log "* DISCONNECT: #{socket?.username}"
    if socket.username
      socket.broadcast.emit 'talk',
        message: "[DISCONNECT] #{socket.username}"

app.listen 3000
console.log "Express server listening on port #{app.address().port}"


<<< views/index.html >>>
<!DOCTYPE html>
<html>
<head>
<title>Chat</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" />
<meta charset="utf-8">
<link href="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.css" rel="stylesheet" type="text/css" />
<link href="/css/stylesheet.less" rel="stylesheet" type="text/less" />
<script src="http://lesscss.org/js/less.js" type="text/javascript"></script>
<script src="http://jashkenas.github.com/coffee-script/extras/coffee-script.js" type="text/javascript"></script>
<script src="/socket.io/socket.io.js" type="text/javascript"></script>
<script src="http://code.jquery.com/jquery-1.7.1.js" type="text/javascript"></script>
<script src="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.js" type="text/javascript"></script>
<script src="/js/application.coffee" type="text/coffeescript"></script>
</head>
<body>
<section id="loading" data-role="page">
Loading...
</section>
<section id="home" data-role="page">
<header data-role="header">
<h1>Chat</h1>
</header>
<div data-role="content">
<p>Welcome!</p>
<form>
<input type="text" name="username" placeholder="Username" />
<input type="submit" value="Enter" />
</form>
</div>
</section>
<section id="chat" data-role="page">
<header data-role="header">
<a href="#home" data-role="button" data-icon="arrow-l" data-direction="reverse">Back</a>
<h1>Chat room</h1>
</header>
<div data-role="content">
<div id="chat-area">
----
</div>
<form>
<input type="text" name="message" placeholder="Input here" />
<input type="submit" value="Send" />
</form>
</div>
</section>
</body>
</html>


<<< public/css/stylesheet.less >>>
#chat-area {
height: 200px;
overflow-y: scroll;
word-wrap: break-word;
}


<<< public/js/application.coffee >>>
$ ->
  socket = io.connect('http://localhost')

  socket.on 'disconnect', (data) ->
    $.mobile.changePage '#home',
      transition: 'flip'

  socket.on 'enter', (data) ->
    $('#chat-area').text('')
    $.mobile.changePage '#chat',
      transition: 'flip'

  socket.on 'talk', (data) ->
    message = $('<p></p>').text(data.message)
    $('#chat-area').append(message)
      .scrollTop($('#chat-area').prop('scrollHeight'))

  $('#home').on 'submit', 'form', ->
    socket.emit 'enter',
      username: $('#home').find('input[name=username]').val()
    false

  $('#chat').on 'submit', 'form', ->
    socket.emit 'talk',
      message: $('#chat').find('input[name=message]').val()
    this.reset()
    false

  $('#chat').on 'click', 'a[href=#home]', ->
    socket.emit 'leave'

  $.mobile.changePage '#home',
    transition: 'pop'



|

댓글 1개

좋은 정보 고맙습니다.
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
13년 전 조회 2,675
13년 전 조회 2,891
13년 전 조회 2,718
13년 전 조회 2,041
13년 전 조회 2,328
13년 전 조회 1,840
13년 전 조회 1,682
13년 전 조회 2,364
13년 전 조회 2,041
13년 전 조회 1,909
13년 전 조회 1,807
13년 전 조회 1,998
13년 전 조회 1,774
13년 전 조회 2,358
13년 전 조회 2,000
13년 전 조회 1,661
13년 전 조회 2,292
13년 전 조회 1,946
13년 전 조회 2,642
13년 전 조회 2,139
13년 전 조회 4,554
13년 전 조회 2,627
13년 전 조회 3,185
13년 전 조회 1,833
13년 전 조회 1,484
13년 전 조회 2,176
13년 전 조회 2,967
13년 전 조회 1,857
13년 전 조회 3,071
13년 전 조회 1,781
13년 전 조회 2,154
13년 전 조회 2,832
13년 전 조회 2,171
13년 전 조회 1,839
13년 전 조회 2,546
13년 전 조회 4,829
13년 전 조회 1,553
13년 전 조회 1,648
13년 전 조회 1,799
13년 전 조회 4,902
13년 전 조회 2,261
13년 전 조회 2,470
13년 전 조회 2,476
13년 전 조회 1,762
13년 전 조회 1,623
13년 전 조회 1,790
13년 전 조회 2,596
13년 전 조회 1,934
13년 전 조회 2,265
13년 전 조회 3,441
13년 전 조회 1,912
13년 전 조회 2,226
13년 전 조회 2,337
13년 전 조회 1,701
13년 전 조회 4,436
13년 전 조회 2,214
13년 전 조회 3,749
13년 전 조회 2,060
13년 전 조회 1,761
13년 전 조회 1,809
13년 전 조회 1,666
13년 전 조회 2,190
13년 전 조회 2,320
13년 전 조회 3,673
13년 전 조회 5,239
13년 전 조회 1,665
13년 전 조회 4,229
13년 전 조회 1,625
13년 전 조회 2,098
13년 전 조회 1,704
13년 전 조회 2,051
13년 전 조회 2,797
13년 전 조회 2,144
14년 전 조회 1,597
14년 전 조회 2,270
14년 전 조회 1,883
14년 전 조회 2,280
14년 전 조회 2,741
14년 전 조회 2,087
14년 전 조회 1,698
14년 전 조회 2,892
14년 전 조회 2,168
14년 전 조회 1,749
14년 전 조회 1,667
14년 전 조회 2,062
14년 전 조회 1,569
14년 전 조회 2,734
14년 전 조회 1,993
14년 전 조회 1,995
14년 전 조회 1,632
14년 전 조회 2,296
14년 전 조회 3,109
14년 전 조회 1,604
14년 전 조회 1,493
14년 전 조회 1,703
14년 전 조회 4,291
14년 전 조회 1,759
14년 전 조회 2,299
14년 전 조회 2,091
14년 전 조회 1,709