서버/클라이언트 스크립트 코드 합쳐서 100줄이 안 되는 간단한 채팅 프로그램입니다.
npm install
npm start
open http://localhost:3000/
{
"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년 전
좋은 정보 고맙습니다.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 6630 |
차가운바람
|
12년 전 | 1173 | |
| 6629 | 12년 전 | 1169 | ||
| 6628 |
put777
|
12년 전 | 652 | |
| 6627 |
|
12년 전 | 708 | |
| 6626 | 12년 전 | 1622 | ||
| 6625 |
|
12년 전 | 729 | |
| 6624 |
미켈란젤로의왼손
|
12년 전 | 495 | |
| 6623 |
|
12년 전 | 1055 | |
| 6622 | 12년 전 | 1405 | ||
| 6621 |
차가운바람
|
12년 전 | 645 | |
| 6620 | 12년 전 | 746 | ||
| 6619 |
|
12년 전 | 983 | |
| 6618 | 12년 전 | 1753 | ||
| 6617 | 12년 전 | 647 | ||
| 6616 |
차가운바람
|
12년 전 | 907 | |
| 6615 | 12년 전 | 2861 | ||
| 6614 | 12년 전 | 623 | ||
| 6613 |
강명구베드로
|
12년 전 | 536 | |
| 6612 |
|
12년 전 | 435 | |
| 6611 | 12년 전 | 1215 | ||
| 6610 | 12년 전 | 1036 | ||
| 6609 | 12년 전 | 3686 | ||
| 6608 |
|
12년 전 | 835 | |
| 6607 | 12년 전 | 702 | ||
| 6606 | 12년 전 | 570 | ||
| 6605 | 12년 전 | 462 | ||
| 6604 | 12년 전 | 980 | ||
| 6603 |
geektoo
|
12년 전 | 714 | |
| 6602 | 12년 전 | 850 | ||
| 6601 | 12년 전 | 374 | ||
| 6600 | 12년 전 | 423 | ||
| 6599 | 12년 전 | 574 | ||
| 6598 | 12년 전 | 956 | ||
| 6597 | 12년 전 | 954 | ||
| 6596 | 12년 전 | 439 | ||
| 6595 | 12년 전 | 797 | ||
| 6594 | 12년 전 | 4579 | ||
| 6593 | 12년 전 | 2583 | ||
| 6592 | 12년 전 | 836 | ||
| 6591 | 12년 전 | 599 | ||
| 6590 |
|
12년 전 | 1410 | |
| 6589 | 12년 전 | 781 | ||
| 6588 |
GINUSSOFT
|
12년 전 | 5136 | |
| 6587 | 12년 전 | 6222 | ||
| 6586 | 12년 전 | 1057 | ||
| 6585 | 12년 전 | 815 | ||
| 6584 | 12년 전 | 477 | ||
| 6583 |
|
12년 전 | 993 | |
| 6582 | 12년 전 | 884 | ||
| 6581 | 12년 전 | 858 | ||
| 6580 | 12년 전 | 627 | ||
| 6579 |
알랑가몰라
|
12년 전 | 943 | |
| 6578 | 12년 전 | 1341 | ||
| 6577 | 12년 전 | 1515 | ||
| 6576 |
경dragon
|
12년 전 | 786 | |
| 6575 | 12년 전 | 1898 | ||
| 6574 | 12년 전 | 698 | ||
| 6573 | 12년 전 | 1002 | ||
| 6572 |
|
12년 전 | 1682 | |
| 6571 |
CTOMAN
|
12년 전 | 1979 | |
| 6570 | 12년 전 | 1743 | ||
| 6569 | 12년 전 | 1902 | ||
| 6568 | 12년 전 | 2415 | ||
| 6567 | 12년 전 | 1037 | ||
| 6566 |
lainfox
|
12년 전 | 1541 | |
| 6565 | 12년 전 | 3667 | ||
| 6564 |
제주프라이스
|
12년 전 | 1545 | |
| 6563 | 12년 전 | 1580 | ||
| 6562 |
프로프리랜서
|
12년 전 | 1362 | |
| 6561 |
프로프리랜서
|
12년 전 | 982 | |
| 6560 |
프로프리랜서
|
12년 전 | 1241 | |
| 6559 |
프로프리랜서
|
12년 전 | 1152 | |
| 6558 |
프로프리랜서
|
12년 전 | 1367 | |
| 6557 |
프로프리랜서
|
12년 전 | 1990 | |
| 6556 |
프로프리랜서
|
12년 전 | 1533 | |
| 6555 |
프로프리랜서
|
12년 전 | 1376 | |
| 6554 |
프로프리랜서
|
12년 전 | 3901 | |
| 6553 |
프로프리랜서
|
12년 전 | 1523 | |
| 6552 | 12년 전 | 859 | ||
| 6551 |
왕초보sasa
|
12년 전 | 1553 | |
| 6550 |
왕초보sasa
|
12년 전 | 649 | |
| 6549 |
왕초보sasa
|
12년 전 | 919 | |
| 6548 | 12년 전 | 1311 | ||
| 6547 | 12년 전 | 1206 | ||
| 6546 | 12년 전 | 5173 | ||
| 6545 | 12년 전 | 2528 | ||
| 6544 |
AnnieK
|
12년 전 | 1794 | |
| 6543 |
베르무트7
|
12년 전 | 661 | |
| 6542 |
오늘도망했다
|
12년 전 | 2244 | |
| 6541 | 12년 전 | 825 | ||
| 6540 | 12년 전 | 1148 | ||
| 6539 | 12년 전 | 858 | ||
| 6538 |
senseme
|
12년 전 | 3384 | |
| 6537 | 12년 전 | 786 | ||
| 6536 | 12년 전 | 3674 | ||
| 6535 | 12년 전 | 1361 | ||
| 6534 | 12년 전 | 1631 | ||
| 6533 | 12년 전 | 2257 | ||
| 6532 |
냐옹이사범
|
12년 전 | 2315 | |
| 6531 | 12년 전 | 576 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기