一、模型属性的一些操作方法

  1、mmodel.get()   获取属性的值

  2、mmodel.set('age',5)  更新单个属性的值

     mmodel.set({name:'aaa',age:6})  更新多个属性的值

     在设置属性值时,如果该属性不存在,会自动创建该属性;同时会以true的形式返回一个模型的引用。

  3、mmodel.unset('age')  从模型中删除一个属性

  4、mmodel.clear()   从模型中删除所有的属性

  5、mmodel.has('age')   检查是否存在某一属性

  6、mmodel.isValid()   手动触发验证,只会返回true或者false,但不会触发invalid

  

二、HTML转义后的属性值

  如果用户输入的文字不是纯文本格式,可能会有一些导致XSS注入攻击的安全漏洞,解决的办法就是任何用户输入文字之前使用escape()

 var  testModel =  new Backbone.Model({
name : "<script>alert(11)</script>"
}); var escaped_name = testModel.escape('name');

三、重写setter 方法和 getter方法

  1、使用原因:

    (1 属性需要变化格式进行存储

    (2 需要一个模型虚拟属性,依赖于其他属性

    (3  防止把非法的值赋值给模型属性

  2、操作:需要引入mutators.js,到https://github.com/asciidisco/Backbone.Mutators下载 backbone.mutators.js 文件,然后引入到项目中

  3、原因(2)demo:

 (function($){

         var testModel = Backbone.Model.extend({

             mutators:{
fullMessage : {
get: function(){
return this.get('name') + ' -and-' + this.get('age');
//return this.name + ' -hh-' + this.age;
}
}
}
}); var t = new testModel;
t.set({
name :'Axiba',
age : 33
});
alert(t.get('fullMessage'));
alert(t.get('name')); })(jQuery);

  4、反过来,重写setter方法的demo,注意key和value:

 (function($){

         var testModel = Backbone.Model.extend({

             mutators:{
fullMessage : {
get: function(){
return this.get('name') + '-and-' + this.get('age');
},
set: function(key, value, options, set){
var message = value.split('-and-');
this.set('name',message[0],options);
this.set('age',message[0],options);
}
}
}
}); var t = new testModel;
t.set({
name :'Axiba',
age : '33'
}); t.set('fullMessage','daomul-and-11'); alert(t.get('fullMessage'));
alert(t.get('name'));
alert(t.get('age')); })(jQuery);

  5、值得注意的是:

    (1 如果是在创建新模型的时候给属性赋值,没有触发到change事件的话,其对应的setter方法是不会触发的。

    (2 新的方法会试图先调用被重写的getter和setter方法,再去调用原始的get() 和 set()

backbone.js之Model篇 简单总结和深入(2)的更多相关文章

  1. Backbone.js之model篇(一)

    Backbone.js之model篇(一) Backbone 是一个前端 JS 代码 MVC 框架,它不可取代 Jquery,不可取代现有的 template 库.而是和这些结合起来构建复杂的 web ...

  2. backBone.js之Model篇 (1) 简单实例

    “Model是js应用的核心,包括基础的数据以及围绕着这些数据的逻辑:数据转换.验证.属性计算和访问控制”. 一.初始化方法 我们先来看一个demo,initialize,这是一个初始化方法,但是写这 ...

  3. [Backbone.js]如何处理Model里面嵌入的Collection?

    写了近半个月的backbone.js代码,从一开始的todo到现在做仿微信的网页聊天,其中最大的困惑就在于如何处理比较复杂的Model,其内嵌了一个或者多个Collections. 假设我们有一个Pe ...

  4. Backbone学习笔记 - Model篇

    2 Model 在Backbone中,Model用于存储核心数据,可以将数据交互相关的逻辑代码放在这里.基本形式如下: var Human = Backbone.Model.extend({ init ...

  5. Backbone之旅——Model篇

    Backbone作为前端的MVC框架,把后端的设计思想带到前端,使前端代码更加清晰.可维护性大大提高 Backbone依赖于underscore.js和jquery,所以在使用backbone的时候一 ...

  6. js学习第二篇简单语法

    字符串(String)字面量 可以使用单引号或双引号 数组(Array)字面量 定义一个数组: [40, 100, 1, 5, 25, 10] 对象(Object)字面量 定义一个对象: {first ...

  7. Backbone.js 中使用 Model

    前面几篇 Backbone.js 的例子中有使用到 template, 及数据的填充,其实这已经很接近 Model 了.现在来学习怎么创建自己的 Model 类,并简单的使用.Backbone.js ...

  8. backbone.js 教程(1) View & Model & Collection

    Backbone.js Overview 它由Jeremy Ashkenas开发,最初发行于2010-10-13 它是一个轻量的JavaScript类库,只依赖于underscore.js,非强制依赖 ...

  9. MVC、MVP、MVVM、Angular.js、Knockout.js、Backbone.js、React.js、Ember.js、Avalon.js、Vue.js 概念摘录

    注:文章内容都是摘录性文字,自己阅读的一些笔记,方便日后查看. MVC MVC(Model-View-Controller),M 是指业务模型,V 是指用户界面,C 则是控制器,使用 MVC 的目的是 ...

随机推荐

  1. 常用的网络上的Webservice接口

    商业和贸易: 1.股票行情数据 WEB 服务(支持香港.深圳.上海基金.债券和股票:支持多股票同时查询) Endpoint: http://webservice.webxml.com.cn/WebSe ...

  2. make screenshot at Eclipse

    In Eclipse, from the Window menu, select Open Perspective > Other... > DDMS. Select the Kindle ...

  3. 小波变换——子带编码,Subband Coding

    离散小波变换.多级信号分解,多分辨率分析. Multiresolution Analysis(MRA.多分辨率分析) 子带编码(Subband Coding) 简称SBC. 一种以信号频谱为依据的编码 ...

  4. 项目管理PMP输入输出ITTO联系记忆

    综述九大领域 项目管理的输入输出非常难记,原因在于理解起来也经不去推敲,故整理一个联想记忆版本,通过联想把输入输出都串起来达到记忆的目的,既然是联想,里面的内容逻辑只是为了好记,并无正确与否,请大家原 ...

  5. mongodb常用操作命令(待续)

    1. 开启mongodb命令 >mongo 默认链接到test数据库 2. 显示所有数据库>show dbs 3.切换数据库>use 数据库名 4.查找数据库里某张表的所有成员> ...

  6. 接口测试之JMeter初探

    1.JMeter安装配置 )登录 http://jmeter.apache.org/download_jmeter.cgi ,下载与自己的平台相对应文件: )安装JDK(.6以上),配置环境变量JAV ...

  7. 【安全开发】python安全编码规范

    申明:本文非笔者原创,原文转载自:https://github.com/SecurityPaper/SecurityPaper-web/blob/master/_posts/2.SDL%E8%A7%8 ...

  8. apt-get/dpkg常用指令备查

    apt-get install <package> Downloads <package> and all of its dependencies, and installs ...

  9. U3D教程宝典之两步实现超实用的XML存档

    两步实现超实用的XML存档 本套存档的优点:易使用,跨平台,防作弊(内容加密 + 防拷贝) 脚本下载地址 使用方法非常简单:把GameDataManager和XmlSaver两个脚本添加至工程后(1) ...

  10. U3D各键值说明

    KeyCode :KeyCode是由Event.keyCode返回的.这些直接映射到键盘上的物理键. 值        对应键 Backspace     退格键 Delete      Delete ...