用Backbone.js创建一个联系人管理系统(四)
原文: Build a Contacts Manager Using Backbone.js: Part 4
这一系列教程的第四部分,教我们如何完成对已经存在的Contacts进行编辑和保存.
本教程是基于这一系列的前三个教程. 有不清楚的请先阅读前三部分.
开始
在Contact原模版里添加一个edit按钮.
<button class="edit">Edit</button>
在原Contact显示模版下添加新的编辑模版
<script id="contactEditTemplate" type="text/template">
<form action="#">
<input type="file" value="<%= photo %>" />
<input class="name" value="<%= name %>" />
<input id="type" type="hidden" value="<%= type %>" />
<input class="address" value="<%= address %>" />
<input class="tel" value="<%= tel %>" />
<input class="email" value="<%= email %>" />
<button class="save">Save</button>
<button class="cancel">Cancel</button>
</form>
</script>
在ContactView的events中添加需要的新事件
"click button.edit": "editContact", //点击class="edit"的button 执行
"change select.type": "addType", //class="type"的select值改变时执行
"click button.save": "saveEdits", //点击class="save"的button 执行
"click button.cancel": "cancelEdit" //点击class="cancel"的button 执行
选择一个Contact来编辑
在Contact model定义中添加新的属性,指定编辑状态Contact用到的模版.
editTemplate: _.template($("#contactEditTemplate").html()),
在ContactView中定义editContact方法的实现.
editContact: function () {
this.$el.html(this.editTemplate(this.model.toJSON()));
var newOpt = $("<option/>", {
html: "<em>Add new...</em>",
value: "addType"
}),
this.select = directory.createSelect().addClass("type") //调用directory的createSelect()方法创建现有的select控件. 值为当前form的隐藏的#type的input值.
.val(this.$el.find("#type").val()).append(newOpt) //在控件里添加新的addType选项.
.insertAfter(this.$el.find(".name")); //把生成的DOM内容放到class="name"的控件后面.
this.$el.find("input[type='hidden']").remove(); //删除原来隐藏的#type的input.
},
增加新的type
在修改Contact时有可能会修改type为之前没有使用过的值.所以我们需要为ContactView添加一个新的方法
addType: function () {
if (this.select.val() === "addType") { //如果当前select的选项是addType
this.select.remove(); //删除select控件
$("<input />", {
"class": "type"
}).insertAfter(this.$el.find(".name")).focus(); //添加一个class="type"的input控件在class="name"控件后.
}
},
更新Contact
编辑完成之后我们还需要为编辑结果进行保存: 为ContactVew添加saveEdits方法.
saveEdits: function (e) {
e.preventDefault();
var formData = {},
prev = this.model.previousAttributes();
$(e.target).closest("form").find(":input").add(".photo").each(function () { //循环form下所有input
var el = $(this);
formData[el.attr("class")] = el.val(); //类名为属性给formdata赋值
});
if (formData.photo === "") {
delete formData.photo; //如果photo为空删掉使用默认值
}
this.model.set(formData);
this.render();
if (prev.photo === "/img/placeholder.png") {
delete prev.photo;
}
_.each(contacts, function (contact) { //循环每个Contact
if (_.isEqual(contact, prev)) { //如果值和原来相等.
contacts.splice(_.indexOf(contacts, contact), 1, formData); //用新的值替换原来的值
}
});
},
假如我们选择放弃自己的编辑,ContactView还需要一个取消编辑的方法
cancelEdit: function () {
this.render();
},
最后就是这个样子了.

这一节的代码下载:
http://cdn.tutsplus.com/net/uploads/legacy/1147_bb3and4/4/demo.zip
注: 原文内容里很多代码有问题. 不过下载后的代码都是可运行的. css文件我不太关注,基本就拷贝下载后源文件里的了.
用Backbone.js创建一个联系人管理系统(四)的更多相关文章
- 用Backbone.js创建一个联系人管理系统(五)
原文: Build a Contacts Manager Using Backbone.js: Part 5 这是这系列教程最后一部分了. 之前所有的增删改都在前端完成. 这部分我们要把Contact ...
- 用Backbone.js创建一个联系人管理系统(一)
原文 Build a Contacts Manager Using Backbone.js: Part 1 在这个教程里我们将会使用Backbone.js,Underscore.js,JQuery创建 ...
- 用Backbone.js创建一个联系人管理系统(二)
欢迎大家回来继续这一教程,第一部分我们学习了model,collection和view在Backbone中的 基本用法,还有怎么样用主视图去绑定collection去渲染出每个Contact. 这部分 ...
- 用Backbone.js创建一个联系人管理系统(三)
原文: Build a Contacts Manager Using Backbone.js: Part 3 欢迎回到这系列的教程,关注使用Backbone.js构建应用程序. 如果你还没看过第一,二 ...
- Vue.js+vue-element搭建属于自己的后台管理模板:创建一个项目(四)
Vue.js+vue-element搭建属于自己的后台管理模板:创建一个项目(四) 前言 本章主要讲解通过Vue CLI 脚手架构建工具创建一个项目,在学习Vue CLI之前我们需要先了解下webpa ...
- 使用 SVG 和 JS 创建一个由星形变心形的动画
序言:首先,这是一篇学习 SVG 及 JS 动画不可多得的优秀文章.我非常喜欢 Ana Tudor 写的教程.在她的教程中有大量使用 SVG 制作的图解以及实时交互 DEMO,可以说教程的所有细枝末节 ...
- 用three.js创建一个简易的天空盒
本文创建的天空盒是用六张图片来创建的.笔者会论述两种方法来创建,都是最简单基本的方法,不涉及着色器的使用.一种是创建一个盒子,然后将图片作为盒子6个面的纹理贴上来创建.另一种则是简单的将纹理作为场景的 ...
- JS创建一个数组1.求和 2.求平均值 3.最大值 4.最小值 5.数组逆序 6.数组去重 0.退出
rs = require("readline-sync"); let arr = []; console.log("请输入数组的长度:"); let arr_l ...
- 用Backbone.js教程系列的链接
整理了一下用Backbone.js系列教程链接. Backbone.js入门教程 用Backbone.js创建一个联系人管理系统(一) 用Backbone.js创建一个联系人管理系统(二) 用Back ...
随机推荐
- Linux不使用useradd创建用户
手动创建用户的全过程:需要管理员权限. 1.在/etc/group中添加用户所属组的相关信息.如果用户还有辅助组则在对应组中加入该用户作为成员. 2.在/etc/passwd和/etc/shadow中 ...
- RequireJS基础(三)
这篇来写一个具有依赖的事件模块event. event提供三个方法bind.unbind.trigger来管理DOM元素事件. event依赖于cache模块,cache模块类似于jQuery的$.d ...
- ios UINaviBar 去除分割线
//For a custom shadow image to be shown, custom background image must also be set with the setBackgr ...
- JAVA反射实践
Java反射机制在我的理解当中就是下面几点: 1. 对一个给定的类名(以字符串形式提供)能动态构建一个对象实例 2. 对于任意一个类,都能够知道这个类的所有属性和方法 3. 对于任意一个对象, ...
- SQL Server(三):Select语句
1.最基本的Select语句: Select [Top n [With Ties]] <*|Column_Name [As <Alias>][, ...n]> From & ...
- ie 出现 append无效
今天发现用ie append 无效,但是在谷歌浏览器上可以使用,问题在于 拼接字符串的时候出现多了一个标签. 解决方法:检查是否有多余或少写html标签.
- 防御病毒邮件得看U-Mail邮件网关
其实在邮件通讯中,那些病毒.垃圾邮件.钓鱼软件也相当危险,在海量邮件中,你没法确定什么时间.哪一封会发起进攻,攻击的目标都有谁?但是一旦得逞,造成的损失又特别大. 最近美国同行又发现了一个新骗局:美国 ...
- 2013xlsm格式文件处理
2013xlsm格式文件处理 2013格式的xlsm文件在低版本打开为空白的处理 1.关闭2013的宏2.打开文件,另存(去打开密码)3.2007打开另存(格式已变为2007)4.仅破解VBA密码5. ...
- VMware中linux硬盘空间不足的解决方法
相信很多人都和我一样是利用虚拟机安装linux的,在玩转linux的时候,可能就会遇到系统提示磁盘空间不足的情况.由于VMware中当初装系统时的设置的最大磁盘容量是不可以动态修改的,所以为我们使用带 ...
- bootstrap 模态 modal 小例子
bootstrap 模态 modal 小例子 <html> <head> <meta charset="utf-8" /> <title ...