Skip to content Skip to sidebar Skip to footer

How To Get Array Element From Model In Backbone.js

I have the following code: Person = new Backbone.Model({ data:[ { age: '27' }, {name: 'alamin'} ] }); now, how can I get the value? person=new Person(); person.get(?); P

Solution 1:

If you're using this model:

Person = new Backbone.Model({

data:[
    { age: "27" },
    {name: "alamin"}
]

});

So if you want to pull from an array within a model explicitly you should try this:

i = new App.Model.Person();
i.fetch();
i.get("data")[0].age;

This would return:

27

From there you can iterate through the data however you prefer.

Solution 2:

I don't know of a data property when defining a model - maybe you mean defaults? as in

var Person = Backbone.Model.extend({
   defaults: {
      property1: value1,
      property2: value2,
      property3: ["arrval1", "arrval2", "arrval3"]
   });

You would retrieve the value of certain property using get: myperson.get('property1'). To set the value of a property use set: myperson.set('property1', 'newValueOfProperty')

If a property is an array the myperson.get('property3')[ index ]

Solution 3:

To get the array as an object:

Use person.get('data')

To get the value of an attribute from the array:

Use person.get('data').name

Or person.get('data')['name']

Solution 4:

To obtain attributes of a specific element of the array:

var people = person.get('data'); // This gets the array of people.var individual = people[0];      // This gets the 0th element of the array.var age = individual.age;        // This gets the age property.var name = individual.name;      // This gets the name property.

Post a Comment for "How To Get Array Element From Model In Backbone.js"