jquery 分页控件(二)
上一章主要是关于分页控件的原理,代码也没有重构。在这一章会附上小插件的下载链接,插件主要就是重构逻辑部分,具体可以下载源文件看下,源代码也有注释。为了测试这个插件是能用的,我弄了个简单的asp.net例子(vs 2010)。通过ajax根据每一页请求数据,数据是使用json格式进行传输,通过knockout.js绑定。在这里顺便推荐一下汤姆大叔的Knockout应用开发指南 ,是学习Knockout非常好的文章。
效果图:

主要思路是通过分页控件的callback方法把 当前页 和 每页显示数量 传给pageselectCallback方法,pageselectCallback请求后台的getModel方法获取当前页的数据,然后数据通过knockout提供的方法把数据绑定到Html控件上。
一、定义请求数据方法
[WebMethod]
public static string getModel(string index, string pagesize)
{
int pageIndex = Int32.Parse(index);
int pageSize = Int32.Parse(pagesize);
Models models = new Models();
IList<Model> allModels = models.getModels();//获取全部数据
if (pageIndex > )
{
pageIndex = pageIndex * pageSize;
}
if (pageSize > (allModels.Count - - pageIndex))
{
pageSize = allModels.Count - - pageIndex;
}
var pageSysmenus = allModels.Skip(pageIndex).Take(pageSize).ToList<Model>();//根据页数和每页显示数量获取数据
string thedata = JsonHelper.ObjDivertToJson(pageSysmenus);//把数据转成json格式 return thedata;
}
//获取总数
[WebMethod]
public static int getCounts()
{
Models models = new Models();
IList<Model> allModels = models.getModels();
int count = allModels.Count - ;
return count;
}
二、knockout 绑定数据
<table class="mytable" border="1" cellspacing="0">
<thead style="background-color: #0AA403">
<tr>
<th>
Id
</th>
<th>
Name
</th>
<th>
TrueName
</th>
<th>
Sex
</th>
<th>
</th>
</tr>
</thead>
<tbody id="tChangeClor" data-bind="foreach: models">
<tr>
<td>
<span data-bind="text: Id"></span>
</td>
<td>
<span data-bind="text: Name"></span>
</td>
<td>
<span data-bind="text: TrueName"></span>
</td>
<td>
<span data-bind="text: Sex"></span>
</td>
<td>
<span data-bind="text: Email"></span>
</td>
</tr>
</tbody>
</table>
<table>
<tr>
<td id="Pagination" class="pagination">
</td>
</tr>
</table>
data-bind绑定的字段要与后台model的字段一致,当然knockout不单只是这个功能,还有数据验证等功能,很好用的一个插件。
三、ajax 请求数据
//定义knockout的viewmodel
var viewModel = function () {
var self = this;
self.models = ko.observableArray();
}
var vm = new viewModel();
//分页控件的callback方法,通过当前页和显示页数请求数据
var pageselectCallback = function (page_index, pagesize) {
var mydata = "{'index':" + page_index + ",'pagesize':" + pagesize + "}";//post到getPage.aspx/getModel的参数
$.ajax({
type: "post",
url: "getPage.aspx/getModel",
data: mydata,
contentType: "application/json;charset=utf-8",
dataType: "json",
success: function (data) {
var datas = data.d;
mappingData(datas);
},
error: function (Request) {
alert(Request.responseText);
}
});
};
var mappingData = function (data) {
var mydata = ko.mapping.fromJSON(data);
vm.models = ko.mapping.fromJS(mydata, {}, vm.models);//把json格式转换成object格式,赋值给models
$('.mytable tbody tr:even').addClass('odd');
};
$(function () {
var getCounts;
$.ajax({
type: "post",
url: "getPage.aspx/getCounts",
contentType: "application/json;charset=utf-8",
dataType: "json",
success: function (data) {
var datas = data.d;
getCounts = Math.ceil(datas / 2);//总页数,向上取整
//调用分页控件插件
$("#Pagination").pagination({
pageSize: 2,
current_page: 1,
display_num: 10,
edge_num: 3,
counts_num:getCounts,
callback: pageselectCallback
});
},
error: function (Request) {
alert(Request.responseText);
}
});
ko.applyBindings(vm, document.getElementById('tChangeClor'));
});
关于ko.mapping.fromJSON(data)还是ko.mapping.fromJS(data)的判断,如果data是string类型( data ='{"Id":1,"Name":"WinKi"}' )就用fromJSON,如果data是object类型( data = {Id:1,Name:"WinKi"} ) 就用fromJS。如果使用$.getJSON()获取数据可以把JSON格式转换成object格式。
这个只是测试例子,实际项目中获取数据部分可以根据存储过程来获取数据,或者把全部的数据先存到缓存中。这样就不会像我例子那样每次都要先查找所有的数据。
如果您觉得还不错,点个推荐吧。
转载请注明出处!谢谢!
jquery 分页控件(二)的更多相关文章
- jquery 分页控件2
jquery 分页控件(二) 上一章主要是关于分页控件的原理,代码也没有重构.在这一章会附上小插件的下载链接,插件主要就是重构逻辑部分,具体可以下载源文件看下,源代码也有注释.为了测试这个插件是能用的 ...
- jquery 分页控件1
jquery 分页控件(一) 以前一直都是用别人的分页控件,虽然用得很爽,但总觉的还是自己写个小插件比较好,这个插件效果.代码等都有参照别人完成的控件.即便功能并不是那么完善,扩展性也不好,bug或许 ...
- jquery 分页控件(一)
以前一直都是用别人的分页控件,虽然用得很爽,但总觉的还是自己写个小插件比较好,这个插件效果.代码等都有参照别人完成的控件.即便功能并不是那么完善,扩展性也不好,bug或许还很多.个人觉得,适合自己用就 ...
- 自己写的简单的jQuery分页控件
因为是内部项目,需要分页控件,网上找了一大堆,给领导一看,都说不行,原因很简单,太复杂,领导就想要个简单点的,类似百度的分页,可是自己也没写过Jquery控件,硬着头皮找了些资料,写了这个分页控件,目 ...
- WPF 自定义分页控件二
一:添加自定义分页控件,命名为KDataPagerTwo: public class KDataPagerTwo : Control, INotifyPropertyChanged { static ...
- jquery 分页控件功能
<script> //分页 function getPageNum(num) { $("#PageNum ul" ...
- jQuery.page 分页控件
分享一下自己在项目中引用的Jquery分页控件 index.html内容 <!DOCTYPE html> <html lang="zh-cn" xmlns=&qu ...
- ajax 分页控件,基于jquery
/* 分页插件,依赖jQuery库 version: 1.1.0 author: Harrison Cao release date: 2013-09-23 相对 v1.0版本 修正了分页居中 使用方 ...
- jQuery Pagination Plugin ajax分页控件
<html> <body> <div id="datagrid"> </div> <div id="paginati ...
随机推荐
- Spark Tungsten揭秘 Day3 内存分配和管理内幕
Spark Tungsten揭秘 Day3 内存分配和管理内幕 恭喜Spark2.0发布,今天会看一下2.0的源码. 今天会讲下Tungsten内存分配和管理的内幕.Tungsten想要工作,要有数据 ...
- 1036. Boys vs Girls (25)
#include <stdio.h>#include <string.h>int main(){ int n,i; while(scanf("%d",&am ...
- 自己动手,丰衣足食。普通键盘实现键盘宏(Windows和Mac版)
很多高端机械键盘,支持宏定义,例如我们可以设置"D"键为"dota",这样当我们按一下宏开启键,再按一下"D"键,就等价于分别按了" ...
- EXTJS 3.0 资料 控件之 itemselector 用法
var dsform = new Ext.data.ArrayStore({ data: [[123, 'One Hundred Twenty Three'], ['1', '今天星期一'], ['2 ...
- 分布式日志收集系统--Chukwa
1. 安装部署 1.1 环境要求 1.使用的JDK的版本必须是1.6或者更高版本,本实例中使用的是JDK1.6 2.使用的hadoop的版本必须是Hadoop0.20.205.1及以上版本,本实例中使 ...
- bnu 4351 美女来找茬(水水)
http://www.bnuoj.com/bnuoj/problem_show.php?pid=4351 [题意]:用最小的矩形框,框住像素点差超过5的点. [题解]:求坐标x,y最大最小值 [cod ...
- jquery bind()方法与live()方法的区别
jquery bind() 方法和 live() 方法都可以绑定元素事件. <!DOCTYPE html> <html> <head> <meta chars ...
- Maven 执行Javadoc时控制台输出乱码问题
1.0 Maven 执行Javadoc时控制台输出乱码问题 问题描述 最近项目中使用maven-javadoc-plugin生成javadoc时,myEclipse控制台乱码. 插件配置 问题分析 ...
- 数据生成器Bogus的使用以及基于声明的扩展
引言 最近在整理代码,发现以前写的一个数据填充器写了一半没实现,而偏偏这段时间就要用到类似的功能,所以正好实现下. 目标 这个工具的目标是能够在项目初期快速搭建一个"数据提供器", ...
- [转载]AOP面向方面编程
1.引言 软件开发的目标是要对世界的部分元素或者信息流建立模型,实现软件系统的工程需要将系统分解成可以创建和管理的模块.于是出现了以系统模块化特性的面向对象程序设计技术.模块化的面向对象编程极度极地提 ...