knockout Ajax异步无刷新分页 Demo +mvc+bootstrap
最近工作中web客户端需要用到knockout,在此记录下一些Demo,以后用到的时候查找起来方便。也希望给新入门的knockout使用者一点经验。knockout官方文档。这儿是一个使用knockout分页的小demo,使用的框架是mvc,javascript框架有jquery,knockout,bootstrap。
先上效果图

前台view
 @{
     //这儿去除该页面的模板页。防止jquery多次引用,当然也可以不去除,下面jquery就可以不用引用了。
     Layout = null;
 }
 @*先引用jquery,然后应用knockout,因为knockout依赖于jquery*@
 <script src="~/Scripts/jquery-1.10.2.js"></script>
 <script src="~/Scripts/knockout-3.2.0.js"></script>
 @*bootstrap,集成到mvc里面的前端开发框架 (官网:http://www.bootcss.com/)*@
 <link href="~/Content/bootstrap.css" rel="stylesheet" />
 <script src="~/Scripts/bootstrap.js"></script>
 <div style="margin:auto;width:500px;text-align:center">
     <div style="margin-top:50px">
         <ul data-bind="foreach:items" style="list-style-type:none">
             <li>
                 <span>Title</span> <span data-bind="text:Title"></span>
                 <span>Content</span><span data-bind="text:Content"></span>
             </li>
         </ul>
     </div>
     <div>
         <button type="button" class="btn btn-primary" data-bind="click:first">
              第一页
         </button>
         <button type="button" class="btn btn-success" data-bind="click:previous">
              上一页
         </button>
         <button type="button" class="btn btn-info" data-bind="click:next">
              下一页
         </button>
         <button type="button" class="btn btn-warning" data-bind="click:last">
             最后一页
         </button>
     </div>
     <div style="margin-top:20px" data-bind="foreach:pageNumbers" class="btn-group" role="group">
         <button data-bind="text:$data,click:$root.gotoPage" type="button" class="btn btn-default">
         </button>
     </div>
 </div>
 @*注意将脚本放在html 代码的下面*@
 <script type="text/javascript">
     function NewsPage() {
         //viewModel本身。用来防止直接使用this的时候作用域混乱
         var self = this;
         //数据
         this.items = ko.observableArray();
         //要访问的页码
         this.pageIndex = ko.observable(1);
         //总计页数
         this.pageCount = ko.observable(1);
         //页码数
         this.pageNumbers = ko.observableArray();
         //当前页
         this.currengePage = ko.observable(1);
         this.refresh = function () {
             //限制请求页码在该数据页码范围内
             if (self.pageIndex() < 1)
                 self.pageIndex(1);
             if (self.pageIndex() > self.pageCount()) {
                 self.pageIndex(self.pageCount());
             }
             //post异步加载数据
             $.post(
                 "/PageList/PageList",
                 {
                     pageIndex: self.pageIndex()
                 },
                 function (data) {
                     // 加载新的数据前,先移除原先的数据
                     self.items.removeAll();
                     self.pageNumbers.removeAll();
                     self.pageCount(data.PageCount)
                     for (var i = 1; i < data.PageCount; i++) {
                         //装填页码
                         self.pageNumbers.push(i);
                     }
                     //for...in 语句用于对数组或者对象的属性进行循环操作。
                     //for ... in 循环中的代码每执行一次,就会对数组的元素或者对象的属性进行一次操作。
                     for (var i in data.PagedData) {
                         //装填数据
                         self.items.push(data.PagedData[i]);
                     }
                 }, "json"
                             )
         }
         //请求第一页数据
         this.first = function () {
             self.pageIndex(1);
             self.refresh();
         }
         //请求下一页数据
         this.next = function () {
             self.pageIndex(this.pageIndex() + 1);
             self.refresh();
         }
         //请求先前一页数据
         this.previous = function () {
             self.pageIndex(this.pageIndex() - 1);
             self.refresh();
         }
         //请求最后一页数据
         this.last = function () {
             self.pageIndex(this.pageCount() - 1);
             self.refresh();
         }
         //跳转到某页
         this.gotoPage = function (data, event) {
             self.pageIndex(data);
             self.refresh();
         }
         this.refresh();
     }
     var viewModel = new NewsPage();
     ko.applyBindings(viewModel);
 </script>
后台controller
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc; namespace KnockOutPageDemo.Controllers
{
public class PageListController : Controller
{
// GET: PageList
public ActionResult Index()
{
return View();
}
/// <summary>
/// 异步请求的分页数据,返回一个json对象
/// </summary>
/// <returns></returns>
public ActionResult PageList()
{
//请求的页码
int pageIndex = int.Parse(Request.Form["pageIndex"]);
//每页显示多少条数据
int pageSize = ;
//取到请求页码的数据
List<News> news = GetNewsData().Skip((pageIndex - ) * pageSize).Take(pageSize).ToList();
//获取总的数据行数
int rowCount = GetNewsData().Count();
//构建数据模型
PageModel pageData = new PageModel()
{
PageIndex = pageIndex,
PagedData = news,
PageCount = rowCount / pageSize };
//返回数据
return Json(pageData, JsonRequestBehavior.AllowGet);
}
public List<News> GetNewsData()
{
List<News> news = new List<News>();
for (int i = ; i < ; i++)
{
news.Add(new News { Title = "天黑黑", Content = "路上小心" });
news.Add(new News { Title = "雨滂滂", Content = "记得带伞" });
news.Add(new News { Title = "人熙熙", Content = "快点回家" });
}
return news;
}
} //分页数据实体
public class PageModel
{//请求页码的数据
public List<News> PagedData { get; set; }
//请求的页码
public int PageIndex { get; set; }
//页码的大小
public int PageSize { get; set; }
//总页数
public int PageCount { get; set; }
//总行数
public int RowCount { get; set; }
}
//新闻模型
public class News
{
public string Title { get; set; }
public string Content { get; set; }
}
}
本文地址:http://www.cnblogs.com/santian/p/4342777.html
knockout Ajax异步无刷新分页 Demo +mvc+bootstrap的更多相关文章
- Ajax 实现无刷新分页
		Ajax 实现无刷新分页 
- 在Thinkphp中使用AJAX实现无刷新分页
		在Thinkphp目录的Lib\ORG\Util\目录里新建AjaxPage.class.php,写入一下内容: <?php // +------------------------------ ... 
- javascript项目实战---ajax实现无刷新分页
		分页: limit 偏移量,长度; limit 0,7; 第一页 limit 7,7; 第二页 limit 14,7; 第三页 每页信息条数:7 信息总条数:select count(*) from ... 
- ajax实现无刷新分页效果
		基于jquery.pagination.js实现的无刷新加载分页数据效果. 简介与说明 * 该插件为Ajax分页插件,一次性加载数据,故分页切换时无刷新与延迟.如果数据量较大,加载会比较慢. * 分页 ... 
- Ajax做无刷新分页
		1.主页面代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www ... 
- 对自写的Asp.Net分页控件的应用方式(异步无刷新分页)
		前台代码 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" co ... 
- ajax 异步无刷新点改
		<button class="status" t_id="{{$v->id}}">{{$v->status}}</button&g ... 
- 学习笔记之AJAX无刷新分页
		利用AJAX实现无刷新分页技术原理: 其主要是利用AJAX的异步处理机制,实现数据的异步传递,它隐藏了客户端向服务端请求数据的状态,在客户端表现为无刷新的显示状态. 实现分页的步骤: 1.客服端点击页 ... 
- thinkphp ajax 无刷新分页效果的实现
		思路:先做出传统分页效果,然后重新复制一份Page.class.php类,对它进行修改,把js中的函数传到page类中,把上一页.下一页.首页.尾页.链接页中的url地址改成js控制的函数,模板页面中 ... 
随机推荐
- C++之共有继承、保护继承、私有继承
			1.封装,public,private作用就是这个目的. 类外只能访问public成员而不能方位private成员: private成员只能被类成员和友元访问: 2.继承,protected的作用就是 ... 
- 物联仓储系统ZigBee组网原理
			在嵌入式项目物联仓储系统中,使用cortexM0模拟仓库,cortex-A9模拟服务器,两块开发板之间使用ZigBee技术实现数据接收和发送,本文就介绍一下ZigBee组网的原理和相关步骤. 1.组网 ... 
- RenderMonkey基本使用方法【转】
			RenderMonkey基本使用方法 楔子: 差不多从年中开始由于工作需要,开始研究Direct3D,这是继大二开始自学DX开始,睽违了6年后再重新学习DX.虽然时间很久了,但是幸亏还是有点基础,所以 ... 
- Shell--数据流重定向
			数据流重定向就是将某个命令执行后应该要出现在屏幕上的数据传输到其他地方 标准 1.标准输入(stdin):代码为0,使用<或<< 2.标准输出(stdout):代码为1.,使用> ... 
- Listener监听器之HttpSessionListener
			编写一个OnlineUserListener. package anni; import java.util.List; import javax.servlet.ServletContext; im ... 
- HTML5 Canvas 绘制库存变化折线
			<!DOCTYPE html> <html lang="utf-8"> <meta http-equiv="Content-Type&quo ... 
- Unity学习笔记 之 关于 Unity UI 的 Slider 的代码记录
			代码例如以下: using UnityEngine; using System.Collections; //1.引入 UI . using UnityEngine.UI; public class ... 
- IOS Appstore价格表
- java.net.ConnectException: failed to connect to /10.0.2.2 (port 80): connect
			在使用GENYMOTION作为Android程序调试模拟器连接web服务器时,报了:java.net.ConnectException: failed to connect to /10.0.2.2 ... 
- C/C++获取当前系统时间
			个人觉得第二种还是比较实用的,而且也是最常用的~ 不过当计算算法耗时的时候,不要忘记second,不能只要用Milliseconds来减,不然后出现负值,若是算法耗时太长就得用minutes啦.再不然 ... 
