Javascrpt 页面工具
/**
* 笔者:DL
* 时间:2014-3-19
* PagingTool模块提供最基本的、网页工具栏。和页面数据 回电话 可扩展性 分页工具栏介绍,和页面呈现的数据
* 主意事项:必须引用json.js
* @module PagingTool
*/
var PagingTool = {}
PagingTool.Init = {} //初始化參数
PagingTool.funPageCallBack = function (data) {
var pParams = data.pParams;//查询參数
var pageCount = data.pageCount;//每页显示条目
var totalPages = data.totalPages;//总页数
var pageIndex = data.pParams.intNowPage; // 当前页
var pageTargetId = data.pageTargetId;
var totalCount = data.totalCount;
var pageHtml = "";
if (totalPages > 1) {
var beginPage = 1, endPage = 1;
beginPage = parseInt((pageIndex - 1) / pageCount) * pageCount + 1;
endPage = parseInt((pageIndex - 1) / pageCount) * pageCount + pageCount;
endPage = endPage > totalPages ?
totalPages : endPage;
if (pageIndex > 1) //上一页
{
pParams["intNowPage"] = 1;
pageHtml += '<a href=\"javascript:;\" onclick=\'PagingTool.Paging(' + JSON.stringify(pParams) + ')\'><<</a>';
pParams["intNowPage"] = pageIndex - 1;
pageHtml += '<a href=\"javascript:;\" onclick=\'PagingTool.Paging(' + JSON.stringify(pParams) + ')\'><</a>'
}
else {
pageHtml += '<a href=\"javascript:;\" ><<</a>'
pageHtml += '<a href=\"javascript:;\" ><</a>'
}
if (beginPage - 1 > 1) {
pParams["intNowPage"] = beginPage - 1;
pageHtml += '<a href=\"javascript:;\" onclick=\'PagingTool.Paging(' + JSON.stringify(pParams) + ')\'>...</a>'
}
//中间页码
for (var i = beginPage; i <= endPage; i++) {
if (pageIndex == i) {
pageHtml += '<a href=\"javascript:;\" class=\"current\"> ' + i + '</a>';
}
else {
pParams["intNowPage"] = i;
pageHtml += '<a href=\"javascript:;\" onclick=\'PagingTool.Paging(' + JSON.stringify(pParams) + ')\'>' + i + '</a>'
}
}
if (totalPages - endPage > 1) {
pParams["intNowPage"] = endPage + 1;
pageHtml += '<a href=\"javascript:;\" onclick=\'PagingTool.Paging(' + JSON.stringify(pParams) + ')\'>...</a>'
}
if (pageIndex < totalPages) {
pParams["intNowPage"] = pageIndex + 1;
pageHtml += '<a href=\"javascript:;\" onclick=\'PagingTool.Paging(' + JSON.stringify(pParams) + ')\'>></a>'
pParams["intNowPage"] = totalPages;
pageHtml += '<a href=\"javascript:;\" onclick=\'PagingTool.Paging(' + JSON.stringify(pParams) + ')\'>>></a>';
}
else {
pageHtml += '<a href=\"javascript:;\" >></a>'
pageHtml += '<a href=\"javascript:;\">>></a>'
}
$("#" + pageTargetId).html(pageHtml);
} else {
$("#" + pageTargetId).html("");
}
}
/**
* 返回当前集合中指定位置的元素
* @method PagingTool.Paging 分页操作方法
* @param {pParams} 查询条件 { "intUstate": 0, "intNowPage": 1, "intType": 1, "intPageSize": 3 }
* @return {HTML} 返回html loadingIcon.gif
*/
PagingTool.Paging = function (pParams) {
var funDCallBack = PagingTool.Init.DataCallBack;
var funPCallBack = PagingTool.Init.PageCallBack
var appendId = PagingTool.Init.AppendId;
var targetId = PagingTool.Init.PageTargetId;
var pageSize = PagingTool.Init.PageSize;
var pageCount = PagingTool.Init.PageCount;
$.ajax({
url: PagingTool.Init.Url,
data: pParams,
type: PagingTool.Init.Type,
dataType: "json",
beforeSend: function () {
var isElement = document.getElementById(appendId).nodeName;
var html = "";
if (isElement == "DIV") {
html = '<div id="sload" style="text-align:center; margin-top:30px;"><image src="/Content/image/base/loadingIcon.gif" /></div>';
}
else {
html = '<tr id="sload"><td colspan="50" style="text-align:center;"><image src="/Content/image/base/loadingIcon.gif" /></td></tr>';
}
$("#" + appendId).html(html);
},
complete: function () {
$("#sload").remove();
},
error: function () {
$("#sload").remove();
},
success: function (data) {
var totalCount = data.TotalCount;
var jieanCount = data.jieanCount;
if (totalCount > 0) {
var totalPages = parseInt((totalCount - 1) / pageSize + 1);
var callDBackParams = { "appendId": appendId, "jsonData": data, "totalCount": totalCount, "jieanCount": jieanCount };
var callPBackParams = { "pageTargetId": targetId, "pageSize": pageSize, "totalPages": totalPages, "pageCount": pageCount, "totalCount": totalCount, "pParams": pParams };
funDCallBack(callDBackParams);//回到函数
funPCallBack(callPBackParams);//分页控件回调函数
}
else {
var desc = returnNull(appendId, 20, "", "");//提示没有数据
$("#" + appendId + "").html(desc);
$("#" + targetId + "").html("");
//没有数据
}
}
});
}
/* 方法说明 使用说明 方法 PageTargetId【分页条呈现位置ID】 AppendId【数据呈现ID】DataCallBack【数据回调函数】PageCallBack【页面呈现回调函数】
PagingTool.Init = { "Url": "/LshSystem/User/AjaxIndex", "Type": "POST", "PageCount": 3, "PageSize": 3, "PageTargetId": "pageId", "AppendId": "appendId", "DataCallBack": funDataCallBack, "PageCallBack": PagingTool.funPageCallBack };
PagingTool.Paging({ "intUstate": 0, "intNowPage": 1, "intType": 1, "intPageSize": 3 });
//数据回调函数 页面操作逻辑
funDataCallBack= function(data) {
var appendId = data.appendId;
var jsonData = data.jsonData.PageData;
var htmlData = "";
for (var i = 0; i < jsonData.length; i++) { //便利数据
htmlData += "<tr id=\"Temp" + i + "\">" +
"<td class=\"thcenter\">" +
"<input type=\"checkbox\" value=\"" + jsonData[i].UAccount + "\" name=\"ckUAccount\" /></td>" +
"<td id=\"UAccount\">" + jsonData[i].UAccount + "</td>" +
"<td id=\"SFName\">" + jsonData[i].SFName + "</td> </tr>"
}
$("#" + appendId + "").html(htmlData);
}
*/
版权声明:本文博客原创文章,博客,未经同意,不得转载。
Javascrpt 页面工具的更多相关文章
- 如何编辑PDF文件,怎么使用PDF裁剪页面工具
在编辑PDF文件的时候,往往会有很多的小技巧可以使用,在编辑PDF文件的时候,怎么对文件的页面进行裁剪呢,不会的话,看看下面的文章吧,小编已经为大家整理好了哦. 1.打开运行PDF编辑器,在编辑器中打 ...
- html页面工具-htmlUnit
HtmlUnit测试工具的推出,创意非常好.是一款给java开发用的browser.说它是browser,其实它是对html建模并且提供API来访问页面,点击链接等等的java类库. 这样的测 ...
- jekyll介绍安装.github静态页面工具
jekyll build # => 当前文件夹中的内容将会生成到 ./site 文件夹中. $ jekyll build --destination <destination> # ...
- 微软Connect教程系列--自动生成增删改查页面工具介绍(二)
本章课程描述了vs2015的三个特点,其中主要将描述在vs2015下面,使用命令自动生成增删改查界面,具体如下: 1.web.config文件不在存在,用config.json替代,以适应支撑vs的插 ...
- javascrpt 页面格式化页面
下面这个页面,格式化javaScript <html> <head> <title>JS格式化工具 </title> <meta http-equ ...
- ASP.NET 数据库页面访问简单工具
在工作中,有很多项目已上线后,很多项目的数据库服务器都不会对外开放的,外网想直接访问客户数据库服务器时,可能会出现困难. 这时就需要一个可以查询,更新数据库操作的页面了: 本来用sql语句直接操作数据 ...
- [转]以Facebook为案例剖析科技公司应有的工具文化
原文:http://36kr.com/p/146507.html 这是一篇几年前的文章,但对于没有涉及到工具文化这个概念的人来说,还是很新的. 前言 前段时间和大众点评的 CEO 张涛聊天的时候碰到内 ...
- ArcGIS空间分析工具
1. 3D分析 1.1. 3D Features toolset 工具 工具 描述 3D Features toolset (3D 要素工具集) Add Z Information 添加 Z 信息 添 ...
- 自定义tld标签,页面使用
背景需求: 系统本身的session不能在页面使用 如下: controller: @RequestMapping(method=RequestMethod.GET) public String ge ...
随机推荐
- JSTL解析——001
JSTL 全称jsp standard tag library ,即jsp标准标签库. 是不是想问标签是什么东西? 标签就是jsp专门用于显示数据的,可重复利用的类库: 是不是想问标签由那些部分组成的 ...
- CListCtrl插入数据避免闪烁
1.锁定窗口,不进行刷新 m_list.LockWindowUpdate(); 2.设定列表不进行重画 m_list.SetRedraw(FALSE); 3.清空列表,删除历史数据 m_list.De ...
- 自定义NavgationBa返回按钮
iOS 上UINavigationController视图压栈形式,可以在当前视图无限制push许多视图,然而一些会觉得自带的push按钮不够美观,而且当上的上一个页面title很长的时候,那个返回 ...
- leetcode Sum Root to Leaf Numbers(所有路径之和)
转载请注明来自souldak,微博:@evagle 观察题目给的返回值类型是int,可以断定这棵树的高度不会超过10,所以数据量其实是非常小的.那就直接dfs遍历这棵树,然后到叶子节点的时候将值加到最 ...
- Linux开发环境的搭建和使用——Linux 常用的命令使用
概要 视或电影中看到过类似的场景,黑客面对一个黑色的屏幕,上面飘着密密麻麻的字符,梆梆一顿敲,就完毕了窃取资料的任务. Linux 刚出世时没有什么图形界面.全部的操作全靠命令完毕.就如同电视里的黑客 ...
- PowerShell 在线教程 4
PowerShell 在线教程 4 认识Powershell 介绍和安装 自定义控制台 快速编辑模式和标准模式 快捷键 管道和重定向 Powershell交互式 数学运算 执行外部命令 命令集 别 ...
- 对TMemoryStream的一些改进(用到了LockFile)
对TMemoryStream的一些改进 怎么又是关于Stream的,呵呵,应该说只是最近比较关心程序的效率问题,而我对Stream其实并没有什么特别的研究,只是自己发现了一些新的用法,希望能对大家有用 ...
- 与众不同 windows phone (26) - Contacts and Calendar(联系人和日历)
原文:与众不同 windows phone (26) - Contacts and Calendar(联系人和日历) [索引页][源码下载] 与众不同 windows phone (26) - Con ...
- Android---OpenGL ES之添加动作
本文译自:http://developer.android.com/training/graphics/opengl/motion.html 在屏幕上绘制对象是OpenGL的最基本功能,你可以使用其他 ...
- Lua获取网络时间
作者:ani_di 版权所有,转载务必保留此链接 http://blog.csdn.net/ani_di Lua获取网络时间 网络授时服务是一些网络上的时间服务器提供的时间,一般用于本地时钟同步. ...