DWR Ext 加载数据_extjs
程序员文章站
2022-04-27 23:03:20
...
一,在Ext中直接使用DWR
1,PoJO的Manager类为
public class CustomerManagerImpl extends HibernateDaoSupport implements CustomerManager {
public PageModel allCustomers() {
PageModel pageModel = new PageModel();
List datas = new ArrayList();
int total ;
String hql = "from Customer";
datas = this.getHibernateTemplate().find(hql);
String countHql = "select count(*) from Customer";
total = ((Long)this.getSession().createQuery(countHql).uniqueResult()).intValue();
pageModel.setDatas(datas);
pageModel.setTotal(total);
return pageModel;
}
}
2,那么直接调用DWR取得数据为(dwr.xml代码参考后面)
var store = new Ext.data.Store({
//data:... 这里有DWR调用直接得到
reader:new Ext.data.JsonReader({id:"sn"},fields), //List数据
sortInfo:{field:'name', direction:'ASC'}// 排序信息
});
//DWR+EXT整合的句子, store.loadData(dataslist);加载数据
//data返回的是PageModel类,属性为total,datas(List数据类型)
//这里不用建立函数,直接执行
JCustomerManager.allCustomers(function(data) {
var total = data.total;
var dataslist=data.datas; //数据为List类型
store.loadData(dataslist); //加载数据
});
3,这里的DWR只做一件事,通过匿名函数,将返回的值的List数据直接注入给store。DWR返回的data可以被JsonStore直接读取,我们需要设置对应的fields参数,以告诉JsonReader需要哪些属性。
4,补充dwr.xml代码
1,PoJO的Manager类为
复制代码 代码如下:
public class CustomerManagerImpl extends HibernateDaoSupport implements CustomerManager {
public PageModel allCustomers() {
PageModel pageModel = new PageModel();
List datas = new ArrayList();
int total ;
String hql = "from Customer";
datas = this.getHibernateTemplate().find(hql);
String countHql = "select count(*) from Customer";
total = ((Long)this.getSession().createQuery(countHql).uniqueResult()).intValue();
pageModel.setDatas(datas);
pageModel.setTotal(total);
return pageModel;
}
}
2,那么直接调用DWR取得数据为(dwr.xml代码参考后面)
复制代码 代码如下:
var store = new Ext.data.Store({
//data:... 这里有DWR调用直接得到
reader:new Ext.data.JsonReader({id:"sn"},fields), //List数据
sortInfo:{field:'name', direction:'ASC'}// 排序信息
});
//DWR+EXT整合的句子, store.loadData(dataslist);加载数据
//data返回的是PageModel类,属性为total,datas(List数据类型)
//这里不用建立函数,直接执行
JCustomerManager.allCustomers(function(data) {
var total = data.total;
var dataslist=data.datas; //数据为List类型
store.loadData(dataslist); //加载数据
});
3,这里的DWR只做一件事,通过匿名函数,将返回的值的List数据直接注入给store。DWR返回的data可以被JsonStore直接读取,我们需要设置对应的fields参数,以告诉JsonReader需要哪些属性。
4,补充dwr.xml代码
复制代码 代码如下:
推荐阅读
-
Ext6 treePanel默认加载两级或多级本地树信息其他加载远程数据
-
Ext6 treePanel默认加载两级或多级本地树信息其他加载远程数据
-
ext combobox动态加载数据库数据(附前后台)
-
ExtJS下 Ext.Direct加载和提交过程排错小结
-
Ext的Viewport,点击左边的tree菜单,让右边tabpanel中的gridpanel列表数据重新加载
-
Ext的Viewport,点击左边的tree菜单,让右边tabpanel中的gridpanel列表数据重新加载
-
Extjs4.1向Ext.grid.Panel创建的gridpanel中动态在第一行插入数据
-
Extjs4.1向Ext.grid.Panel创建的gridpanel中动态在第一行插入数据
-
Extjs中从数据库获取并加载json字符串的小问题
-
Ext中下拉列表ComboBox组件store数据格式用法介绍_extjs