快速浏览更多在线 Demo

想查看源代码,可以自行F12,或在github中直接查看源码,或者欢迎直接留言。

一、界面设计:

二、数据模型设计

id 每个发言都有一个独立的id由tastypie自动生成

content 发言的内容

username 发言者

date 发言时间

三、前端制作

这里没有用到Backbone的Router,因为这里不需要记录hash记录

1.Div+CSS制作静态页面,这里item-template为每一个发言的模版

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<style type="text/css">
ul, li {
margin:0px;
padding:0px;
list-style:none;
}
body {
}
#wrapper {
width:1000px;
margin:0px auto;
}
#wrapper .header {
width: 100%;
background-color: rgb(46, 177, 232);
}
#wrapper .content {
width: 100%;
}
#wrapper .content .username {
color: red;
}
#wrapper .content .time {
color: orange;
}
#wrapper .content .item_content {
color: blue;
}
#wrapper .content_ul, #wrapper .item {
background-color: rgb(237, 237, 237);
padding: 10px;
}
#wrapper .destroy{
color: green;
font-weight: bold;
cursor: pointer;
}
#wrapper .footer {
width:100%;
float: left;
background-color: rgb(46, 177, 232);
padding: 10px 0px;
}
#wrapper .footer .fl {
width:80%;
float:left;
}
#wrapper .footer .fr{
width:20%;
float:left;
}
#wrapper .footer .fr::after {
clear:both;
}
#new_chat {
width: 100%;
height: 80px;
}
#wrapper .footer .fr_up {
margin-left: 30px;
margin-bottom: 10px;
}
#wrapper .footer .fr_down {
margin-left: 30px;
}
#nickname {
width: 97px;
}
#wrapper .footer .send {
width: 150px;
background-color: green;
display: block;
text-align: center;
padding: 20px;
text-decoration: none;
} </style>
</head>
<body>
<div id="wrapper">
<div class="header">
[ Chat Room Beta 1.0 ]
</div>
<div class="content">
<ul class="content_ul">
</ul>
</div>
<div class="footer">
<div class="fl"><textarea id="new_chat" autofocus></textarea></div>
<div class="fr">
<div class="fr_up">
呢称:<input id="nickname" type="text"/>
</div>
<div class="fr_down">
<button class="send" id="send">发送消息</button>
</div>
</div>
</div>
</div>
<script type="text/template" id="item-template">
<span class="username"><%=username %></span> : <span class="time"><%=date %></span> <a class="destroy">X</a><br />
<span class="item_content"><%=content %></span>
</script> <script src="/static/chatroom/js/vendor/jquery.js"></script>
<script src="/static/chatroom/js/vendor/underscore.js"></script>
<script src="/static/chatroom/js/vendor/backbone.js"></script>
<script src="/static/chatroom/js/models.js"></script>
<script src="/static/chatroom/js/views.js"></script>
</body>
</html>

2.Backbone Models 文件,为了方便,这里把model与collection都放到同一文件了,\static\chatroom\js\models.js

var Chat = Backbone.Model.extend({

    urlRoot: '/api/v1/chat/',

    defualts: {
content: '',
username: '',
date: ''
}, clear: function () {
this.destroy();
}
}); var ChatList = Backbone.Collection.extend({ url: '/api/v1/chat/',
parse: function (response) {
return response.objects;
}, model: Chat });

3.Backbone Views文件,为了方便,参照todoMVC把视图划分为两个,一个是ChatView用于每个发言,一个为AppView用于整体处理,这里把ChatView与AppView都放到同一文件了,\static\chatroom\js\views.js

var chatList = new ChatList;//New 一个Collection下面会用到
var ChatView = Backbone.View.extend({
tagName: 'li',
className: 'item', template: _.template($('#item-template').html()),
events: {
'click .destroy': 'clear'
}, initialize: function () {
_.bindAll(this, 'render', 'remove');
this.model.bind('change', this.render);
this.model.bind('destroy', this.remove);
}, render: function () {
$(this.el).html(this.template(this.model.toJSON()));
This = $(this.el).find('.time');
This.text(This.text().split('.')[0].replace('T',' '));//注意这里tastypie提供的时间格式为:2015-03-01T23:52:26.854388 所以要对时间进行格式化一下
return this;
}, clear: function () {
this.model.clear();
}
}); var AppView = Backbone.View.extend({
el: $('#wrapper'), events: {
"click #send": "say"
}, initialize: function () {
_.bindAll(this, 'addOne', 'addAll');
this.nickname = this.$('#nickname');
this.textarea = this.$("#new_chat"); chatList.bind('add', this.addOne);
chatList.bind('reset', this.addAll);
chatList.fetch();
setInterval(function () {
chatList.fetch({ add: true });
}, 5000);
}, addOne: function (chat) {
//页面所有的数据都来源于server端,如果不是server端的数据,不应添加到页面上
if (!chat.isNew()) {
var view = new ChatView({ model: chat });
this.$(".content_ul").append(view.render().el);
$('.content').scrollTop($(".content_ul").height() + 50);
}
}, addAll: function () {
chatList.each(this.addOne);
}, say: function (event) {
chatList.create(this.newAttributes());
//为了满足IE和FF以及chrome
this.textarea.text('');
this.textarea.val('');
this.textarea.html(''); }, newAttributes: function () { var content = this.textarea.val();
if (content == '') {
content = this.textarea.text();
} return {
content: content,
username: this.nickname.val()
};
}
}); var appView = new AppView;//启动程序

到这里前端代码已经完成。

四、后端处理

这里用Django自带的SQLite作后台数据库

1.Django Model文件-D:\project\mysite\ChatRoom\models.py

from django.db import models

class Chat(models.Model):
content = models.CharField(max_length=1024)
username = models.CharField(max_length=1024)
date = models.DateTimeField(auto_now_add=True)

2.配置TastyPie API文件-D:\project\mysite\ChatRoom\api\resources.py

from tastypie.authorization import Authorization
from tastypie import fields
from tastypie.resources import ModelResource
from ChatRoom.models import Chat class ChatResource(ModelResource):
class Meta:
queryset = Chat.objects.all()
resource_name = 'chat'
authorization = Authorization()
fields=['id','username','content','date']

3.Restfull API的Url文件配置-D:\project\mysite\mysite\urls.py

from django.conf.urls import patterns, include, url
from tastypie.api import Api
from ChatRoom.api.resources import ChatResource v1_api = Api(api_name='v1')
v1_api.register(ChatResource()) urlpatterns = patterns('',
url(r'^admin/', include(admin.site.urls)),
url(r'^api/', include(v1_api.urls)),
)

把数据库导好及配置好Tastypie,运行测试,可以正常留言!

参考引用

http://www.the5fire.com/

https://github.com/tastejs/todomvc

实践:Backbone作前端,Django+Tastypie作后端的简单Web在线聊天室的更多相关文章

  1. Django+Tastypie作后端,Backbone作前端的TodoMVC

    TodoMVC是各种js框架入门的比较经典的例子,详细可查看github地址https://github.com/tastejs/todomvc 接着上篇文章, 1,先在github上把backbon ...

  2. Django+Tastypie作后端,RequireJS+Backbone作前端的TodoMVC

    一.配置好环境 接着前一篇的例子,顺带测试一下已下载下来example里面的backbone_require的例子 注意:直接本地用backbone.localStorage插件运行TodoMVC会报 ...

  3. Go语言实践_实现一(服务器端)对多(客户端)在线聊天室

    一.目的 运用Go语言中的goroutine和通道实现一个简单的一个服务器端对多个客户端的在线聊天 软件环境:Goland,Go1.9 代码仓库链接 二.设计思路 与一对一的设计思路类似,就是加了个线 ...

  4. Go语言实践_实现一(客户端)对一(服务器端)聊天室

    一.目的 使用Go语言实现一个服务器端与客户端的聊天室. 软件:Goland,Go1.9 代码仓库地址 二.思路 1,首先启动服务器端,使用listen_socket函数监听IP地址上的客户端连接: ...

  5. WebSocket 网页聊天室的实现(服务器端:.net + windows服务,前端:Html5)

    websocket是HTML5中的比较有特色一块,它使得以往在客户端软件中常用的socket在web程序中也能轻松的使用,较大的提高了效率.废话不多说,直接进入题. 网页聊天室包括2个部分,后端服务器 ...

  6. python + django + dwebsocket 实现简单的聊天室

    使用库dwebsocket,具体参考此处 views.py: from dwebsocket.decorators import accept_websocket,require_websocket ...

  7. Django 前端通过json 取出后端数据

    Django 前端通过json 取出后端数据 前端通过json 取出后端数据 步骤1:后台数据通过 JSON 序列化成字符串a 注意:1.json是1个字符串 ​ 2.通过json.dumps('xx ...

  8. 解决Django+Vue前后端分离的跨域问题及关闭csrf验证

      前后端分离难免要接触到跨域问题,跨域的相关知识请参:跨域问题,解决之道   在Django和Vue前后端分离的时候也会遇到跨域的问题,因为刚刚接触Django还不太了解,今天花了好长的时间,查阅了 ...

  9. 前端angularjs+requirejs+dhtmlx 后端asp.net webapi

    享一个前后端分离方案源码-前端angularjs+requirejs+dhtmlx 后端asp.net webapi   一.前言 半年前左右折腾了一个前后端分离的架子,这几天才想起来翻出来分享给大家 ...

随机推荐

  1. CRM(客户关系管理)

    CRM最初是由Gartner Group提出的. CRM定义:"客户关系管理(CRM),是代表增进赢利.收入和客户满意度而设计的,企业范围的商业战略." 我们可以看出,Gartne ...

  2. Python Day8

    Socket Socket是网络编程的一个抽象概念.通常我们用一个Socket表示"打开了一个网络链接",而打开一个Socket需要知道目标计算机的IP地址和端口号,再指定协议类型 ...

  3. js日期格式转换

    var mydate=new Date(); var year=mydate.getFullYear(); //获取四位数getYear() 获取两位 var month=mydate.getMont ...

  4. 迭代器学习之一:使用IEnumerable和IEnumerator接口

    写博客是检验我学习的成果之一以及自我总结的一种方式,以后会经常利用这种方式进行技术交流和自我总结,其中认识不深难免会有错误,但是一直懂得不懂就问,不懂就学的道理! 1.首先看一个简单的列子 , , , ...

  5. PHP解决抢购、秒杀、抢楼、抽奖等阻塞式高并发库存防控超量的思路方法

    如今在电商行业里,秒杀抢购活动已经是商家常用促销手段.但是库存数量有限,而同时下单人数超过了库存量,就会导致商品超卖甚至库存变负数的问题. 又比如:抢购火车票.论坛抢楼.抽奖乃至爆红微博评论等也会引发 ...

  6. C# Httpclient编程

    今天研究了一天C#如何添加cookie到httpcient里面,从而发请求时,能把cookie作为头部发出,最后发现根本加不进去. Httpclient的cookie是来自上一个请求的响应,httpc ...

  7. Hbase过滤器Filter的使用心得(爬坑经验)

    Hbase 的过滤器是个好东西.. 给这种非关系型数据库本来不能复杂查询的情况得到了很好的扩展..提供了很多的帮助.. 但是Filter的种类何其之多..让人眼花缭乱.. 譬如..分页类型的PageF ...

  8. java 实现文件下载

    需求:把每天产生的日志文件,从服务器上下载下来 File file = new File(path); // 根据路径,获取File String filename = file.getName(); ...

  9. 反射的一些用法(WP8.1下)

    我初步的理解:反射就是动态调用(dll)类. 比如某个dll有一个类,通过反射就可以知道它里面属性.方法,就可以实现调用. 确实,dll可以直接引用,但是如果遇到这种情况: 添加.删除功能同属一个Dl ...

  10. nyoj 71 独木舟上的旅行(贪心专题)

    独木舟上的旅行 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能乘坐两个人,且乘客 ...