Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Backbone validate function not getting called

Tags:

backbone.js

My validate function is not getting called in the code below:-

var Vehicle = Backbone.Model.extend({
    color: 'green',
    validate: function (attrs) {
        var validColors = ['white', 'red', 'blue', 'yellow'];
        var colorIsValid = function (attrs) {
            if (!attrs.color) return true;
            return _.contains(validColors, attrs.color);
        }
        if(!colorIsValid(attrs)) {
            return "color must be one of: " +validColors.join(",");
        }
    }
});

var car = new Vehicle();

car.on('error', function (model, error) {
    console.log(error);
});

console.log(car.get('color'));
car.set('color', 'muave');

Please see fiddle http://jsfiddle.net/vineet85/Fa8jr/5/

Can someone tell me why the validate function is not getting called?

like image 543
Vineet Avatar asked Jan 21 '13 18:01

Vineet


Video Answer


1 Answers

In Backbone.js validate is called automatically on save but not on set.

If you want validations to run when setting a value you will need to use the validate option. e.g.

car.set('color', 'muave', {validate: true});

See http://backbonejs.org/#Model-validate

The error event is triggered when an error occurs, typically on the server, when trying to save the object. See http://backbonejs.org/#Events-catalog

If you want to catch validation failures try handling the invalid event:

car.on('invalid', function (model, error) {
    console.log(error);
});
like image 117
Steve Avatar answered Oct 13 '22 03:10

Steve