zoukankan      html  css  js  c++  java
  • Backbone 学习3

    (function($){
        var Item=Backbone.Model.extend({
            defaults:{
                part1:"hello",
                part2:"world"
            }
        })
        var List=Backbone.Collection.extend({
            model:Item
        })
        var ListView=Backbone.View.extend({
            el:$("body"),
            events:{
                "click button#add":"addItem"
            },
            initialize:function(){
                _.bindAll(this,"render","addItem","appendItem");
                this.collection=new List();
                this.collection.bind('add',this.appendItem);
    
                this.counter=0;
                this.render();
            },
            render:function(){
                var slef=this;
                $(this.el).append("<button id='add'>Add list item</button>");
                $(this.el).append("<ul></ul>");
                _(this.collection.models).each(function(item){
                    self.appendItem(item);
                },this);
            },
            addItem:function(){
                this.counter++;
                var item=new Item();
                item.set({
                    part2:item.get("part2")+this.counter
                });
                this.collection.add(item);
            },
            appendItem:function(item){
                $("ul",this.el).append("<li>"+item.get("part1")+" "+item.get("part2")+"</li>");
            }
        })
        var listView=new ListView();
    })(jQuery)
  • 相关阅读:
    面向对象之绑定方法与非绑定方法
    Django-admin源码解析
    单例模式
    Django-admin管理工具
    Django-CBV
    叠加装饰器,三元表达,生成,调用,递归
    迭代器与生成器
    有参装饰器
    储备知识与装饰器
    文件修改
  • 原文地址:https://www.cnblogs.com/wangwenfei/p/Backbone_javascript.html
Copyright © 2011-2022 走看看