Part 4: CRUD Operations on BackboneJs Models using HTTP REST Service

In this article we will discuss how we can perform CRUD operations on a backbone model using a REST based HTTP service.

[size=large][b]Background[/b][/size]

Earlier we have discussed about the benefits of using backbone.js and we also looked at the backbone models.

In this article we will look at performing the CRUD operations on backbone models using a REST based web service.

Link to complete series:

[list]
[*][url=http://since1027.iteye.com/blog/2306301]Part 1: Introduction to Backbone.Js[/url]
[*][url=http://since1027.iteye.com/blog/2306311]Part 2: Understanding the basics of Backbone Models[/url]
[*][url=http://since1027.iteye.com/blog/2306332]Part 3: More about Backbone Models[/url]
[*][url=http://since1027.iteye.com/blog/2306344]Part 4: CRUD Operations on BackboneJs Models using HTTP REST Service[/url]
[*][url=http://since1027.iteye.com/blog/2306346]Part 5: Understanding Backbone.js Collections[/url]
[*][url=http://since1027.iteye.com/blog/2306355]Part 6: Understanding Backbone.js Views[/url]
[*][url=http://since1027.iteye.com/blog/2306361]Part 7: Understanding Backbone.js Routes and History[/url]
[*][url=http://since1027.iteye.com/blog/2306566]Part 8: Understanding Backbone.js Events[/url]
[/list]
[color=brown][size=large][b]Using the code[/b][/size][/color]

The first thing we will do is that we will create a simple REST based web api that can be used to save the data on the server using our simple backbone application. For this I have created a simple database with a single table as:

[img]http://i1.wp.com/rahulrajatsingh.com/wp-content/uploads/2014/07/DB.jpg?w=284[/img]

The ID field is configured to auto increment and this is the primary key of the table. so while creating a new model we don’t have to provide this to the server. Now on top of this model, I have written a simple ASP.NET web api that will provide us the RESTful api. This API is configured to run on my local machine at: http://localhost:51377/. The API details are as follows:

[list]
[*][b]Create:[/b] POST http://localhost:51377/api/values
[*][b]Read:[/b] GET http://localhost:51377/api/values/{id}
[*][b]Update:[/b] PUT http://localhost:51377/api/values/{id}
[*][b]Delete:[/b] DELETE http://localhost:51377/api/values/{id}
[/list]
Once we have the API running, we can start working on our backbone model. We had create the backbone model in our previous article as:

var Book = Backbone.Model.extend({
defaults: {
ID: "",
BookName: ""
},
idAttribute: "ID",
initialize: function () {
console.log('Book has been initialized');
this.on("invalid", function (model, error) {
console.log("Houston, we have a problem: " + error)
});
},
constructor: function (attributes, options) {
console.log('Book\'s constructor had been called');
Backbone.Model.apply(this, arguments);
},
validate: function (attr) {
if (!attr.BookName) {
return "Invalid BookName supplied."
}
}
});

The backbone models inherently supports saving on the server using a restful web api. To save the model using a HTTP REST service, we need to specify the urlRoot in the backbone model. To actually save the model, we can call the save on the backbone model.The save method will trigger the validations and if the validations are successful, it will try to identify the action to be performed i.e. create or update and based on that action, it will use urlRoot and call the appropriate REST API to perform the operation. Let us specify the URL root to enable this model to use our web api service.

var Book = Backbone.Model.extend({
defaults: {
ID: "",
BookName: ""
},
idAttribute: "ID",
initialize: function () {
console.log('Book has been initialized');
this.on("invalid", function (model, error) {
console.log("Houston, we have a problem: " + error)
});
},
constructor: function (attributes, options) {
console.log('Book\'s constructor had been called');
Backbone.Model.apply(this, arguments);
},
validate: function (attr) {
if (!attr.BookName) {
return "Invalid BookName supplied."
}
},
urlRoot: 'http://localhost:51377/api/Books'
});

Now let us try to perform CRUD operations on this model.

[size=large][b]Create[/b][/size]

To create a new entity on the server, we need to populate the non identity fields in the model (other than ID in this case) and then call the Save method on the model.

// Lets perform a create operation [CREATE]
var book = new Book({ BookName: "Backbone Book 43" });
book.save({}, {
success: function (model, respose, options) {
console.log("The model has been saved to the server");
},
error: function (model, xhr, options) {
console.log("Something went wrong while saving the model");
}
});

[size=large][b]Read
[/b][/size]
To read a single book entity, we need to create the book entity with the identity attribute populated, i.e., the ID of the book we want to read. Then we need to call the fetch method on the model object.

// Now let us try to retrieve a book [READ]
var book1 = new Book({ ID: 40 });
book1.fetch({
success: function (bookResponse) {
console.log("Found the book: " + bookResponse.get("BookName"));
}
});

[size=large][b]Update[/b][/size]

Now let’s say we want to update the name of the book retrieved in the earlier fetch call. All we need to do is set the attributes we need to update and call the save method again.

// Lets try to update a book [UPDATE]
var book1 = new Book({ ID: 40 });
book1.fetch({
success: function (bookResponse) {
console.log("Found the book: " + bookResponse.get("BookName"));
// Let us update this retreived book now (doing it in the callback) [UPDATE]
bookResponse.set("BookName", bookResponse.get("BookName") + "_updated");
bookResponse.save({}, {
success: function (model, respose, options) {
console.log("The model has been updated to the server");
},
error: function (model, xhr, options) {
console.log("Something went wrong while updating the model");
}
});
}
});

[size=large][b]Delete[/b][/size]

Now to delete a Model, we just need to call the destroy method of the model object.

// Let us delete the model with id 13 [DELETE]
var book2 = new Book({ ID: 40 });
book2.destroy({
success: function (model, respose, options) {
console.log("The model has deleted the server");
},
error: function (model, xhr, options) {
console.log("Something went wrong while deleting the model");
}
});

[size=large][b]Custom URLs to perform CRUD operation on models[/b][/size]

There are few scenarios where we might want to have provide custom URLs for the individual operations. This can be achieved by overriding the sync function and providing custom URL for each action. Let us create one more model BookEx to see how this can be done.

var BookEx = Backbone.Model.extend({
defaults: {
ID: "",
BookName: ""
},
idAttribute: "ID",

// Lets create function which will return the custom URL based on the method type
getCustomUrl: function (method) {
switch (method) {
case 'read':
return 'http://localhost:51377/api/Books/' + this.id;
break;
case 'create':
return 'http://localhost:51377/api/Books';
break;
case 'update':
return 'http://localhost:51377/api/Books/' + this.id;
break;
case 'delete':
return 'http://localhost:51377/api/Books/' + this.id;
break;
}
},
// Now lets override the sync function to use our custom URLs
sync: function (method, model, options) {
options || (options = {});
options.url = this.getCustomUrl(method.toLowerCase());

// Lets notify backbone to use our URLs and do follow default course
return Backbone.sync.apply(this, arguments);
}
});

Now we can perform the CRUD operations on this model in the same way as we did for the previous model.

[size=large][b]Point of interest[/b][/size]

In this article we have looked at how to perform CRUD operations on backbone models using HTTP based REST service. This has been written from a beginner’s perspective. I hope this has been informative.

原文链接:[url]http://rahulrajatsingh.com/2014/07/backbone-tutorial-part-4-crud-operations-on-backbonejs-models-using-http-rest-service/[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值