Skip to main content

Ext JS 4 - Ajax Proxy

Ajax proxy in Ext JS is most widely used one for reading and writing information from/to web server. The configuration of ajax proxy is applied either in store or model class and it is based on the following criteria.

  1. We need to define our proxy configuration in model class whenever we need to reuse the same model in various stores with same proxy configuration.

  2. We need to define our proxy configuration in store class whenever we need to reuse the same model class in various stores with various proxy configuration.

Let's see an example for Ajax proxy. Here I am getting JSON data from web server and displaying those data by using grid component.

User.js - Model

Ext.define('MyApp.model.User',{
 extend : 'Ext.data.Model',
 
 fields : [{
  name : 'id', type : 'int'
 }, {
  name : 'userName', type : 'String'
 }, {
  name : 'email', type : 'String'
 }]
 
});
  

User.js - Store

Ext.define('MyApp.store.User',{
 extend : 'Ext.data.Store',
 storeId : 'users',
 //autoLoad : true,
 model : 'MyApp.model.User',
 proxy : {
  type : 'ajax',
  url : 'data/users.json',
  reader : {
   type : 'json',
   root : 'users',
   successProperty : 'success'
  }
 }
});
  

Here, the important thing is proxy configuration. I have set the proxy type as 'ajax' and specified the server URL for loading and updating data. We can use different URL for performing read and update operation.

The reader is another configuration is used for decoding server response and it updates the store based on the decoded information. Here I have used JSON reader, apart form JSON reader Ext JS provide some more readers like Array and XML. The reader is very handy if you are loading nested data from server.

For performing read operation, ajax proxy send a GET request and for performing create, delete and update operations it send a POST request to server.

We can't use ajax for reading information from other domains because it's violating DOM security principles . For talking to other domains, we need to use JSONP proxy.

In real application, we have to send some extra parameters to server. In this situation we need to use ajax proxy extraParams configuration. Check the Ext JS sencha documentation for getting more information about AJAX proxy.

UserList.js - View

Ext.define('MyApp.view.UserList',{
 extend : 'Ext.panel.Panel',
 alias : 'widget.userlist',
 title : 'Users Information',
 width : 400,
 height : 300,
 items : [{
  xtype : 'gridpanel',
  store : 'User',
  columns : [{
   text : 'User Identity', dataIndex : 'id', flex : 1
  }, {
   text : 'User Name', dataIndex : 'userName' , flex : 1
  }, {
   text : 'Email', dataIndex : 'email', flex : 1
  }]
 }]
});

Here, I have used the grid component for displaying store data.

UserList.js - Controller

Ext.define('MyApp.controller.UserList',{
 extend : 'Ext.app.Controller',
 models : ['User'],
 stores : ['User'],
 views : ['UserList'],
 
 init : function() {
  this.getStore('User').load();
  this.callParent();
 }
});

In controller init function, I have taken the User store handle and called the load function. In this situation, the ajax request is send to server for loading data.

app.js

Ext.Loader.setConfig({
 enabled : true
});

Ext.application({
 name : 'MyApp',
 appFolder : 'app',
 controllers : ['UserList'],
 launch : function() {
  Ext.create('MyApp.view.UserList',{
   renderTo : Ext.getBody()
  });
 }
});

Result

Comments

Popular posts from this blog

Ext JS 4 – Creating web page using Ext.container.Viewport class and region propery

The Ext.container.Viewport is used for creating general web page and region property is used for splitting web page into different parts. Ext.container.Viewport is a specialized container represents the viewable area of the application (the browser area). It render itself to the document body, there is no need for providing renderTo property and it automatically sizes itself to size of the browser viewport. The viewport also re-size the child elements based on view area(based on browser width and height). The default layout of the viewport is border layout and we can customize this property according to our requirements. The viewport does not provide any scrolling. If necessary, the child elements(generally panels) within viewport needs to provide a scroll feature by using autoScroll property. See the below example for better understanding. This is Home.js file placed into app/view folder. Ext.define('MyApp.view.Home', { extend : 'Ext.container.Viewport&#

Simple Login Application Using Spring MVC and Hibernate – Part 1

 I hope developers working in web application development might hear about MVC architecture. Almost all technologies provide support for MVC based web application development, but the success is based on many factors like reusable of the code, maintenance of the code, future adaption of the code, etc..,  The success of the Spring MVC is “ Open for extension and closed for modification ” principle. Using Spring MVC the developers can easily develop MVC based web application. We don’t need any steep learning curve at the same time we need to know the basics of spring framework and MVC architecture. The Spring MVC consists of following important components. 1. Dispatcher servlet 2. Controller 3. View Resolver 4. Model Spring MVC - Overview  The overall architecture of Spring MVC is shown here.  1. When “Dispatcher Servlet” gets any request from client, it finds the corresponding mapped controller for the request and just dispatches the request to the corresponding contro

Getting key/value pair from JSON object and getting variable name and value from JavaScript object.

 Hi, I had faced one issue like this. I have an JSON object but I don't know any key name but I need to get the all the key and corresponding value from JSON object using client side JavaScript. Suddenly I wondered whether it's possible or not, after that I had done lot of workaround and finally got this solution. See the below example.    function getKeyValueFromJSON() {     var jsonObj =  {a:10,b:20,c:30,d:50} ;     for ( var key in jsonObj) {       alert( "Key: " + key + " value: " + jsonObj[key]);     }  }  In this example I have created the one json array as string, and converted this string into JSON object using eval() function. Using for-each loop I got all the key value from jsonObj, and finally using that key I got the corresponding value.  Finally I got the alert like this,    Key: a value:10    Key: b value:20    Key: c value:30    Key: d value:50  During this workaround I got one more idea, using this same way I got