backbonejs mvc框架的增删查改实例
一:开发环境
coffeescript和nodejs需要先安装,没装网上自己查安装步骤。
代码编写环境及esp框架下载:
esp框架下载地址:https://github.com/nonocast/esp.git
在下载目录执行安装命令:npm install esp
这样开发环境就已经安装好了。
二:backbonejs 增删查改实例代码
backbonejs的学习可以网上下载电子书“backbonejs的入门教程”,及http://backbonejs.org/官网上学习
1:html部分
结构是由一个编辑模版和一个table行模版组成。
body ->
div 'header', -> 'BACKBONEJS MVC DEMO'
div 'add-block', ->
input type:'button',id:'addbtn',value:'添加'
span id: "showblock", style:'display:none;', ->
text '姓名:'
input type:text,id:'a-name'
text '性别:'
input type:text,id:'a-gender'
text '科目:'
input type:text,id:'a-subject'
text '成绩:'
input type:text,id:'a-score'
input type:'button',id:'savebtn',value:'保存'
table ->
caption '学生成绩汇总列表'
tr ->
th style:'width:10%;', -> '编号'
th style:'width:15%;', -> '姓名'
th style:'width:15%;', -> '性别'
th style:'width:15%;', -> '科目'
th style:'width:15%;', -> '成绩'
th style:'width:20%;', -> '操作'
script type:'text/template',id:'trtemplate', ->
tr 'tr<%=id%>', ->
td 'id<%=id%>', -> '<%=id%>'
td 'name<%=id%>', -> '<%=name%>'
td 'gender<%=id%>', -> '<%=gender%>'
td 'subject<%=id%>', -> '<%=subject%>'
td 'score<%=id%>', -> '<%=score%>'
td 'do', ->
a id:'tredit<%=id%>', href:'#',->'编辑'
a id:'trdelete<%=id%>', href:'#',->'删除' script type:'text/template',id:'edittemplate', ->
tr 'tr<%=id%>', ->
td 'id', ->'<%=id%>'
td 'name', ->
input 'name<%=id%>',type:'text',value:'<%=name%>'
td 'gender', ->
input 'gender<%=id%>',type:'text',value:'<%=gender%>'
td 'subject', ->
input 'subject<%=id%>',type:'text',value:'<%=subject%>'
td 'score', ->
input 'score<%=id%>',type:'text',value:'<%=score%>'
td 'do', ->
a id:'save<%=id%>', href:'#',->'确认'
2:js mvc框架部分
M---model(类结构)
C----collection(数据集合)
V----View(页面级别的,与页面绑定,事件的绑定等)

Model的defaults可以是一些默认的类型结构,也可以什么默认结构都没有,自己在使用过程中定义类型结构,在Model模块中主要是为了某个属性发生变化时触发所绑定的事件功能。

在Collection模块中,url主要是与后台交互的接口,所有的数据交互都通过此url,提交的数据带有id的此框架会自动转为PUT协议, 没有id的新增数据为Post协议,挺奇怪的吧
model表明该Collection是上面$model类型结构的集合

View模块中,el:表明该页面级要操作的元素的区域,最大也就为body了。在view中操作的元素都需要包含在此el中,有点象作用域
events:此处元素事件绑定,注:此处绑定的事件需要涉及的dom元素在执行到该处时就已经载入,比如模块中的编辑删除按钮就不能在这里绑定事件,因为这些按钮在view初始化后的构造函数中render才呈现出来,此时绑定会找不到这些元素。
that = @ @为this指针,this指向当前的view,在很多地方用到该句来备份指针,目的是在单击等事件里的指针会发生变化,会指向当前的元素,用that以便能调用view内定义的方法.
新增一条记录时,需要手动加入到collection里面,再提交到后台,可以用collection.create新增记录,也可以通过model来创建一条记录,然后手动添加到collection,此时需要走model的url来save,而不是collection的url来save,如下:
saveclick: ->
that = @ #此处的备份指针,以便能调用view内定义的方法,在单击等事件里的指针会发生变化,指向当前的元素
#n =new $model 通过model创建的数据保存到后台之后(需要走model里的url到后台),需要在collection手动加入该条记录,而通过collction先创建这条记录(走collection
#的url到后台),不需要再手动添加
@collection.create {name:$("#a-name").val(), gender:$("#a-gender").val(),subject:$("#a-subject").val(),score:$("#a-score").val()},
success:(mod,res) ->
e = _.template $("#trtemplate").html()
$("table").append(e mod.attributes)
i = mod.get "id"
$("#tredit"+i).click ->
that.editclick i
$("#trdelete"+i).click ->
that.deleteclick i
$("#showblock").css("display","none")
error: ->
alert 'error'
三:esp后台代码
esp = require 'esp'
esp.route ->
data = []
data.push {id:1,name:'测试1',gender:'male',subject:'语文',score:'80'}
data.push {id:2,name:'测试2',gender:'male',subject:'数学',score:'90'}
data.push {id:3,name:'测试3',gender:'male',subject:'英语',score:'88'}
data.push {id:4,name:'测试4',gender:'male',subject:'语文',score:'70'}
data.push {id:5,name:'测试5',gender:'male',subject:'数学',score:'90'} @get '/', ->@view 'home' @get '/data', -> @json data @post '/data', ->
i = data[data.length-1].id+1
model = {}
d = ''
@request.on 'data',(chunk) -> d += chunk
@request.on 'end', =>
obj = JSON.parse d
console.log obj
model = {id:i,name:obj.name,gender:obj.gender,subject:obj.subject,score:obj.score}
data.push model
@json model @delete '/data/:id', ->
for each, i in data
if each.id.toString() is @id
data.splice i,1
@json id:@id @put '/data/:id', ->
d = ''
@request.on 'data',(chunk) -> d += chunk
@request.on 'end', =>
obj = JSON.parse d
console.log obj.name
for each, i in data
if each.id == obj.id
each.name = obj.name
each.gender = obj.gender
each.subject = obj.subject
each.score = obj.score
@json each
四:实现页面效果

以上实现了一个简单增删改的实例,练习了backbonejs mvc框架的使用。有些描述是自己的理解,有不正确的地方望大伙指正。
backbonejs mvc框架的增删查改实例的更多相关文章
- SSH2 增删查改实例
(一)引入包 (共73个,不一定都需要,但是我的项目是这么多,经过调试,没有包冲突) (二)创建数据库表 建立数据库octtest,并创建user表,表里面一共4个字段:id,姓,名,年龄. 语句如下 ...
- (新)自己动手写ORM框架(1)-增删查改的使用
之前写过一个系列文章自己动手写ORM框架,经过在多个项目的中的使用,对这套代码进行了许多改进,下面是使用方法: 新增学员信息代码预览: DBHelper db = DBHelper.getInstan ...
- [转].NET MVC 分页以及增删查改
本文转自:http://blog.csdn.net/sust2012/article/details/30761867 . 数据库操作,DAL 层: using System; using Syste ...
- Yii框架基础增删查改
返回一条数据 Country::find()->one(); 返回所有数据 Country::find()->all(); 返回记录的数量 $country =Country::find( ...
- elasticsearch的python增删查改实例分析
Reference: http://bigg.top/2015/11/29/elasticsearch%E7%9A%84python%E5%A2%9E%E5%88%A0%E6%9F%A5%E6%94 ...
- backbonejs mvc框架
backbonejs mvc框架的增删查改实例 一:开发环境 coffeescript和nodejs需要先安装,没装网上自己查安装步骤. 代码编写环境及esp框架下载: esp框架下载地址:https ...
- 6.在MVC中使用泛型仓储模式和依赖注入实现增删查改
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...
- knockout+MVC+webapi+sqlserver完成增删查改
快过年了,公司的事情较少,想着开始学习点新东西.这段时间一个项目用到了mvc和webapi,然后一直对knockout比较感兴趣,就想着用这个框架做一个小实例.数据库采用的是sqlserver.话不多 ...
- 在MVC中使用泛型仓储模式和依赖注入实现增删查改
标签: 原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository ...
随机推荐
- ABAP断点调试
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- Open SQL详解
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- 屏幕序列Screen Sequences
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- SQL Group By/Having
有时候需要检查DataBase里面是不是存在重复的数据,那么比较常用的就是通过Group By来进行分组,然后Having出来,如下: ))
- DB层面上的设计 分库分表 读写分离 集群化 负载均衡
第1章 引言 随着互联网应用的广泛普及,海量数据的存储和访问成为了系统设计的瓶颈问题.对于一个大型的 互联网应用,每天几十亿的PV无疑对数据库造成了相当高的负载.对于系统的稳定性和扩展性造成了极大的 ...
- SQL SERVER赋权限
--创建登录账户 use master GO EXEC sp_addlogin 'jacky', 'pwd' --EXEC sp_droplogin 'jacky' --删除登陆账户 use Test ...
- 妙用||和&&
&&和||在JQuery源代码内尤为使用广泛,由于本人没有系统的学习js,所以只能粗略的自我理解出来,希望大家指点下.粗略理解如下: a() && b() :如果执行a ...
- iOS - Swift 数据持久化
1.Sandbox 沙箱 iOS 为每个应用提供了独立的文件空间,一个应用只能直接访问为本应用分配的文件目录,不可以访问其他目录,每个应用自己独立的访问空间被称为该应用的沙盒.也就是说,一个应用与文件 ...
- Java抓取网页数据(原网页+Javascript返回数据)
有时候由于种种原因,我们需要采集某个网站的数据,但由于不同网站对数据的显示方式略有不同! 本文就用Java给大家演示如何抓取网站的数据:(1)抓取原网页数据:(2)抓取网页Javascript返回的数 ...
- HIHO线段树(成段)
#include <stdio.h> #define lson l,mid,id<<1 #define rson mid+1,r,id<<1|1 ; ],lazy[ ...