ObjectStore onFetch方法获取记录总数

转自:http://blog.csdn.net/earthhour/article/details/38686029

ObjectStore onFetch方法获取记录总数

require([‘dojo/when‘]);
var json = new JsonRest({target: url});

    store = new ObjectStore({objectStore: json});

    store.onFetch = function(results){
        // 方法一:
    	results.then(function(rs){
    		console.log(‘rs len->‘,rs.length);
    	});
        // 方法二:
    	when(results, function(results){
    		console.log(‘when->‘,results.length);
    		console.dir(results);
    	});
    };

  

dojo小例子(14)对提供给grid显示的数据进行预处理

有时我们从后台获取的数据不一定能满足页面显示的需求,比如后台数据中某个字段值是“1/0”,但是显示时我们希望显示为“是/否”。这就需要对数据进行转换,也就是预处理。

可以有两种方法,假设使用场景是JsonRest+ObjectStore组合为grid提供懒加载数据。

方法一、对store中的数据进行预处理。

[javascript] view plaincopy

  1. var json = new JsonRest({
  2. target: url
  3. });
  4. var store = new ObjectStore({objectStore: json});
  5. store.onFetch = function(results){
  6. results.forEach(function(item){
  7. // 在这里预处理数据
  8. if(item.admin == ‘1‘){
  9. item.admin = ‘是‘;
  10. }else{
  11. item.admin = ‘否‘;
  12. }
  13. });
  14. };

方法二、在grid的structure中预处理。

[javascript] view plaincopy

  1. var layout = [
  2. [{
  3. ‘name‘: ‘Column 1‘,
  4. ‘field‘: ‘id‘,
  5. ‘width‘: ‘100px‘
  6. }, {
  7. ‘name‘: ‘Column 2‘,
  8. ‘field‘: ‘admin‘,
  9. ‘width‘: ‘100px‘,
  10. get: function(colIndex, item) {
  11. // processing data
  12. if (item.admin == ‘1‘) {
  13. return ‘是‘;
  14. } else {
  15. return ‘否‘;
  16. }
  17. }
  18. }, {
  19. ‘name‘: ‘Column 3‘,
  20. ‘field‘: ‘desc‘,
  21. ‘width‘: ‘200px‘
  22. }]
  23. ];

另外,遇到带内部对象的json数据,例如:

{"name":"陈","age":"24","phone":{"company":"123","home":"456","private":"789"}}

我们想把内部对象的属性company显示到grid,如果这样写‘field‘: ‘phone.company‘肯定行不通,所以也适合用上面提到的两种方法之一进行转换。

假如采用第二种方法:

[javascript] view plaincopy

  1. {
  2. ‘name‘: ‘Column 2‘,
  3. ‘field‘: ‘phone.company‘,
  4. ‘width‘: ‘100px‘,
  5. get: function(colIndex, item) {
  6. // processing data
  7. return item.phone.company;
  8. }
  9. }

2014-5-13更新:

采用第二种方法时,对grid刷新会不起作用,就是由于get方法导致。代码如下:

[javascript] view plaincopy

  1. Grid.resize();
  2. Grid._refresh();

目前原因不清楚。所以如果需要用到grid刷新,还是采用第一种方式

时间: 2024-11-01 14:06:04

ObjectStore onFetch方法获取记录总数的相关文章

MySQL高效获取记录总数

通常mysql获取查询记录总数我们使用如下语句: SELECT COUNT(*) FROM users WHERE k='avs';  或:SELECT id FROM goods WHERE k='avs' LIMIT 10; 但是记录总数总是需要单独的语句来查询,例如在分页查询程序中就有这样的问题,其实mysql可以在一次查询中获取记录和总数的,这就是要使用SQL_CALC_FOUND_ROWS参数,使用方法如下: SELECT SQL_CALC_FOUND_ROWS goods WHERE

PHP MYSQL 获取记录总数

$qid = mysql_query("SELECT count(aid) as total FROM table group by aid ");//你的查询 $res = mysql_fetch_array($qid); $count = $res['total']; //取出统计值 如果你不想加as total,那么$count = $res[0];

分页总数计算,根据总记录数获取分页总数_目标科技

分页总数计算,根据总记录数获取分页总数,本文章提供5种写法,大家感觉哪个好用就拿去用吧. int pageSize = 20; //每页记录数量 int totalCount = 100005; //总记录数 int pageCount; //总页数 //方法一: pageCount = (totalCount + pageSize - 1) / pageSize; //推荐写法 //方法二: pageCount = (totalCount - 1) / pageSize + 1; //方法三:

[Android Pro] 关于inputStream.available()方法获取文件的总大小

reference to :http://hold-on.iteye.com/blog/1017449 如果用inputStream对象的available()方法获取流中可读取的数据大小,通常我们调用这个函数是在下载文件或者对文件进行其他处理时获取文件的总大小. 以前在我们初学File和inputStream和outputStream时,有需要将文件从一个文件夹复制到另一个文件夹中,这时候我们用的就是inputStream.available()来获取文件的总大小,而且屡试不爽. 但是当我们要

jquery中ajax如何返回值到上层函数的方法以及对于js处理json对象方法的记录

①在我们做前端js处理的时候我们经常会将一些公用的js方法封装起来,方便别的地方调用,但是我们要做的是需要将请求返回的值传递给调用者,这里我记录了在js中采用ajax方法获取后台数据并返回给调用者的方法,我们平时使用ajax的方法基本为如: <span style="font-family:FangSong_GB2312;font-size:18px;">function AutoGetOpenid(){ var personJson; $.ajax({ url : &qu

(判断url文件大小)关于inputStream.available()方法获取下载文件的总大小

转自:http://hold-on.iteye.com/blog/1017449 Java代码   如果用inputStream对象的available()方法获取流中可读取的数据大小,通常我们调用这个函数是在下载文件或者对文件进行其他处理时获取文件的总大小. 以前在我们初学File和inputStream和outputStream时,有需要将文件从一个文件夹复制到另一个文件夹中,这时候我们用的就是inputStream.available()来获取文件的总大小,而且屡试不爽. 但是当我们要从网

依据记录总数和每页大小取页数(转)

依据记录总数和每页大小取页数例如:总记录数为totalrow,每页显示数为pagesize,现在要求总页数totalpage1 常用方法:整除,判断余数,余数大于0,整除结果加1. if(totalrow%pagesize==0) totalpage=totalrow/pagesize; else totalpage=totalrow/pagesize+1; 这种计算方法,会导致程序先取余数,再比较是否有余数,再进行整除操作,然后再进行相加操作2 今天无意间发现还有另外一种计算方式(以前没怎么多

实例365(6)---------DateTime.ToString格式化日期,使用DateDiff方法获取日期时间的间隔数

一:DateTime.ToString格式化日期,截图 二:代码 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace TmrFormat { public part

thinkphp I方法获取不到值、filter_var

用的TP的I方法,设置I('key','',"string") 当前台传入"<>"等html标签的时间发现,I方法获取不到值,追了下Tp的代码.I方法有段这样的代码: $data   =   filter_var($data,is_int($filter) ? $filter : filter_id($filter)); 当用string过滤的时候,相当于filter_var("<ssss>",FILTER_SANITIZ