user2439931
user2439931

Reputation: 11

Backbone script doesn't work

I'm new to Backbone Framework and this is my first app. I couldn't see any rendering of my app's view in my browser. I've checked the error console and didn't find any errors. Could you guys have a look and help me? I appreciate your time on my behalf and many thanks in advance

<!DOCTYPE HTML>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="http://documentcloud.github.com/underscore/underscore-min.js"></script>
<script src="http://documentcloud.github.com/backbone/backbone-min.js"></script>
<script src="http://ajax.cdnjs.com/ajax/libs/json2/20110223/json2.js"></script>
<script id="contactTemplate" type="text/template">
    <h1> <%= name %> </h1>
    <dl>
        <dt> <%= address %> </dt>
        <dt> <%= tel %> </dt>
        <dt> <%= email %> </dt>
        <dt> <%= type %> </dt>
    </dl>
</script>
<script>
  // Your code goes here
 (function ($) {

 /* Dummy JSON DataSet */   
 var contacts = [
                 {name:"Test1",address:"Test Address",tel:"0123",email:"[email protected]",type:"family"},
                 {name:"Test2",address:"Test Address",tel:"01234",email:"[email protected]",type:"friends"},
                 {name:"Test3",address:"Test Address",tel:"012345",email:"[email protected]",type:"office"}
                 ];

 /* Defining Model */ 
 var Contact = Backbone.Model.extend({
    defaults:{
        name:'',
        address:'',
        tel:'',
        email:'',
        type:''
    }
    });

 /* Defining Collection (Set of Models) */
 var Directory = Backbone.Collection.extend({
    model:Contact
    });

 /* View for rendering indivijual Model*/
 var ContactView = Backbone.View.extend({
    tagName:'div',
    className:'contact-container',
    template:$('#contactTemplate').html(),
    render:function(){
        var tmpl = _.template(this.template);        
        this.$el.html(tmpl(this.model.toJSON()));
        return this;
    }
    });

 /* View for rendering collection of Models */
 var DirectoryView = Backbone.View.extend({
    el:$("#contacts"),
    intialize:function(){        
        this.collection = new Directory(contacts);
        this.render();
    },
    render:function(){
        var that = this;
        _.each(this.collection.models, function(item){
            this.renderContact(item);
            },this);
    },
    renderContact:function(item){
        var contactView = new ContactView({
            model:item
        });        
        this.$el.append(contactView.render().el);
    }
    });

 /* Initializing the view */
 var directory = new DirectoryView(); 
} (jQuery));
</script>
</head>
<body>
<div id="contacts">    
</div>
</body>
</html>

Upvotes: 1

Views: 353

Answers (2)

Ulug&#39;bek
Ulug&#39;bek

Reputation: 2832

@akoskm's answer is correct, and i changed your code a few look like this:

ContactView = Backbone.View.extend({
    tagName: 'div',
    className: 'contact-container',
    template: $('#contactTemplate').html(),
    render: function(){
       var tmpl = _.template(this.template,this.model.toJSON());        
       this.$el.html(tmpl);
       return this;
   }
});


DirectoryView = Backbone.View.extend({
    el: "#contacts",
    initialize: function(options){        
        contacts = options.contacts
        this.collection = (new Directory(contacts)).models;
        this.render();
    },
    render: function(){
        var that = this;
        _.each(this.collection, function(item){
            this.renderContact(item);
            },this);
    },
    renderContact: function(item){
        var contactView = new ContactView({
            model: item
        });
        this.$el.append(contactView.render().el);
    }
});

Upvotes: 0

Akos K
Akos K

Reputation: 7133

Beware,

 (function ($) {...})(jQuery)

won't guarantee that your code will be executed when the DOM is ready. At the time of rendering DirectoryView, <div id="contacts"> isn't yet available so $el is also undefined.

Putting your script after </body> or into document.ready will solve your problem.

You also have a typo here:

    el:$("#contacts"),
    intialize: function(){    // <- initialize: function()    
        this.collection = new Directory(contacts);
        this.render();
    } 

Upvotes: 1

Related Questions