Backbone.js学习之Model




首先,我们看一下官方文档中对Model的解释(或者说定义):
Models are the heart of any JavaScript application, containing the interactive data as well as a large part of the logic surrounding it: conversions, validations, computed properties, and access control. You extend Backbone.Model with your domain-specific methods, and Model provides a basic set of functionality for managing changes.
翻译成中文就是:
Model是js应用的核心,包括交互数据以及围绕着这些数据的大部分逻辑:数据转换、验证、属性计算和访问控制。你可以使用特定方法来扩展Backbone.Model,并且Model本身就提供了一系列基本的管理功能。
然后,我们还在文档中看到Model拥有好多方法,这里就不一一介绍了。

简单的Model例子

定义了一个最基础的Model,只是实现了initialize这个初始化方法。这个函数会在Model被实例化时调用。
var Man = Backbone.Model.extend({
        constructor: function(){
            alert(‘Hey, you create me!‘);
        }
         });
        var man = new Man;

初始化函数,也可以叫构造函数。比如你这里完全可以把constructor写成initialize,效果是一样的。至于为什么一样?这还得等到熟悉这个框架过后看看Backbone源码才能知道。

Molde对象属性赋值的两种方法

一种是设置默认值

        var Man = Backbone.Model.extend({
        initialize: function(){
            alert(‘Hey, you create me!‘);
        },
        defaults: {
            name:‘张三‘,
            age: ‘38‘
        }
    });
    var man = new Man;
    console.info(man.get("name"));

或者这样赋值

    man.set({name:‘the5fire‘,age:‘10‘});
    console.info(man.get("name"));
    console.info(man);

从这个对象的取值方式可以知道,属性在一个Model是以字典(或者类似字典)的方式存在的,第一种设定默认值的方式,只不过是实现了Backbone的defaults这个方法,或者是给defaults进行了赋值。通过打印出man这个对象,我们可以发现,属性是存在一个叫做attributes的对象中的。

Model对象中的方法

var Man = Backbone.Model.extend({
        initialize: function(){
            alert(‘Hey, you create me!‘);
        },
        defaults: {
            name:‘张三‘,
            age: ‘38‘
        },
        aboutMe: function(){
            return ‘我叫‘ + this.get(‘name‘) + ‘,今年‘ + this.get(‘age‘) + ‘岁‘;
        }
    });
    var man = new Man;
    alert(man.aboutMe());

也是比较简单,只是增加了一个新的属性,值是一个function。说到这,不知道你是否发现,在所有的定义或者赋值操作中,都是通过字典的方式来完成的,比如extend Backbone的Model,以及定义方法,定义默认值。方法的调用和其他的语言一样,直接 . 即可,参数的定义和传递也一样。

监听Model对象中属性的变化

假设你有在对象的某个属性发生变化时去处理一些业务的话,下面的示例会有帮助。依然是定义那个类,不同的是我们在构造函数中绑定了name属性的change事件。这样当name发生变化时,就会触发这个function。

var Man = Backbone.Model.extend({
        initialize: function(){
            alert(‘Hey, you create me!‘);
            //初始化时绑定监听
            this.bind("change:name",function(){
                var name = this.get("name");
                alert("你改变了name属性为:" + name);
            });
        },
        defaults: {
            name:‘张三‘,
            age: ‘38‘
        }
    });
    var man = new Man;
    //触发绑定的change事件,alert。
    man.set({name:‘the5fire‘});

    //触发绑定的change事件,alert。
    man.set({name:‘the5fire.com‘});

为Model对象添加验证规则,以及错误提示

var Man = Backbone.Model.extend({
        initialize: function(){
            alert(‘Hey, you create me!‘);
            //初始化时绑定监听, change事件会先于validate发生
            this.bind("change:name",function(){
                var name = this.get("name");
                alert("你改变了name属性为:" + name);
            });
            this.bind("invalid",function(model,error){
                alert(error);
            });
        },
        defaults: {
            name:‘张三‘,
            age: ‘38‘
        },
        validate:function(attributes){
            if(attributes.name == ‘‘) {
                return "name不能为空!";
            }
        }
    });
    var man = new Man;
    // 这种方式添加错误处理也行
    // man.on(‘invalid‘, function(model, error){
    //         alert(error);
    // });

    //默认set时不进行验证
    man.set({name:‘‘});
    //save时触发验证。根据验证规则,弹出错误提示。
    man.save();

    //手动触发验证, set时会触发
    man.set({name:‘moyi‘}, {‘validate‘:true});
    //验证通过时信息
    if (man.isValid()) {
  alert(man.get("name")+"验证通过");
}


其他精彩文章

jQuery教程(19)-jquery ajax操作之序列化表单

jQuery教程(18)-ajax操作之执行POST请求

jQuery教程(17)-ajax操作之向服务器传递数据 执行GET请求

jQuery教程(16)-ajax操作之加载XML文档

jQuery教程(15)-ajax操作之执行脚本

jQuery教程(14)-ajax操作之操作 JavaScript 对象

更多关于android开发文章

时间: 2024-07-29 01:10:31

Backbone.js学习之Model的相关文章

【转】Backbone.js学习笔记(二)细说MVC

文章转自: http://segmentfault.com/a/1190000002666658 对于初学backbone.js的同学可以先参考我这篇文章:Backbone.js学习笔记(一) Backbone源码结构 1: (function() { 2: Backbone.Events // 自定义事件 3: Backbone.Model // 模型构造函数和原型扩展 4: Backbone.Collection // 集合构造函数和原型扩展 5: Backbone.Router // 路由

Backbone.js学习之二

经历一段自我修炼,终于领悟到Backbone.js的关键知识点,也发现了原来MVC可以在前端这样梦幻的发挥,Backbone.js确实是一个很有魅力的前端MVC框架. 练就一门技术,需要有扎实的功底,从这点,开始认真研究Backbone.js的一些最基本的操作,以便我日后学习能更上一层楼.那就切入主题: 什么是mvc? 简单的理解就是:模型(models),视图(views),控制器(collections).通过视图把浏览器的网址传给控制器,控制器对网址进行解析,然后去模型层获取数据,模型层将

Backbone.js学习之一

昨天一个我崇拜的朋友,徐飞送我一本名为<Backbone.js实战>书,让我心中狂喜,于是带着这份浓厚的兴趣,开始研究Backbone.js之路. 打开这本书的第一句话就很有哲理,“授人以鱼,不如授之以渔.”,我花了一段时间仔细的看完了的第一章节,今天通过自己所理解的, 记录下我自学的第一步.其他不多说,进入主题: 首先在学习Backbone.js之前要了解Backbone.js是什么? 在我看来它是一个处理前端MVC很好的js框架,Backbone是一个非常轻量级的javascript库,自

【转】Backbone.js学习笔记(一)

文章转自: http://segmentfault.com/a/1190000002386651 基本概念 前言 昨天开始学Backbone.js,写篇笔记记录一下吧,一直对MVC模式挺好奇的,也对js中MVC的开创鼻祖怀着敬畏之心,唉,不说了,好虚伪,以下是我的学习心得和笔记. 给大家看一下全球js库和框架的使用比例:这是通过搜索引擎抓取script标签统计而来的数据,可信度相当高啊,另外,不要迷恋Angular.js,Avalon.js还是挺不错的. 什么是Backbone.js? Back

Backbone.js 中使用 Model

前面几篇 Backbone.js 的例子中有使用到 template, 及数据的填充,其实这已经很接近 Model 了.现在来学习怎么创建自己的 Model 类,并简单的使用.Backbone.js 中 Model 会涉及到很多的概念,如 Model 的初始化,默认值,属性的读写,属性值改变的监听,数据渲染,校验,以及与服务端的数据同步等. 本文不打算讲前面大部分的内容,最初思考的一个脉络是怎么把 Model 引入进来,所以线索会是 建立 Model 类 -> 初始化 Model 实例 ->

Backbone.js学习之旅(一)

前言 刚到粑粑公司,就学习各种框架,进行各种开发,为了纪念挥泪的青春,只好写下…… 希望能合您胃口^_^!!! The First(文件准备) backobone 强制依赖于 underscore.js , 非强制依赖于 jQuery. underscore下载地址:http://www.css88.com/doc/underscore/; backbone下载地址:http://www.css88.com/doc/backbone/; 创建目录结构如下(您所看到的js文件均是第三方库文件):

Backbone.js学习(1)---为什么要学习backbone?

通常面对一个新鲜事物,各种各样的问题总是成为促使我们去学习,探索的第一驱动力. 对于Backbone,今天主要提出以下几个问题: 我们为什么需要Backbone? 这个框架怎么样,他的优点和缺点呢,它的适用场景呢? 前端框架很多,为什么选择backbone学习? 一.我们为什么需要Backbone? 随着前端技术的发展,用户硬件的飞速提升,浏览器的不断改进,一些以前需要在服务端完成的任务,现在可以移到客户端去完成,特别是现在进入多用户端的时代,web应用的开发模式也面临着巨大的挑战.mvc思想为

Backbone.js之model篇(一)

Backbone.js之model篇(一) Backbone 是一个前端 JS 代码 MVC 框架,它不可取代 Jquery,不可取代现有的 template 库.而是和这些结合起来构建复杂的 web 前端交互应用. Backbone 主要包括 models, collections, views 和 events, controller. (一)model 关于 backbone,最基础的一个东西就是 model,这个东西就像是后端开发中的数据库映射那个 model 一样,也是数据对象的模型,

Backbone.js入门学习笔记目录

//来自 https://www.the5fire.com/backbone-tutorials-catalogue.html 1.初识backbone.js 2.通过helloworld来认识下backbone 3.backbone中的model实例 4.backbone的collection实例 5.backbone中的Router实例 6.backbone中的view实例 7.backbone实例todos分析(一) 8.backbone实例todos分析(二)view的应用 9.back