zendFream 中的用到了Ajax(其中有搜索)分页
最近在用ZendFreamwork开发一个后台,其中用到了分页,ZendFreamwork自带的分页挺好用的,可是我其中用到了Ajax的局部刷新,在加上一些搜索条件,所以分页有点无头绪了。下面我来介绍下我的方法:
1.首页我这个页面有两种选择情况我用a(渠道)和b(应用) 代替了,如果搜索的条件是a中的,那么就执行a 方法,如果是b 就执行b 方法,只刷新下边的列表部分
这里面php部分不说了,ZendFreamwork的分页可以看下手册,只说其中我认为最重要的(关键当时这个地方不会)
我的模板页面都是用js写的如何传参和执行的php方法名称:(可能写的不是很好,请见谅)
html页面:
<dl>
<dt>渠道:<input type="radio" name="type" value="1" checked="checked" /></dt>
<dd>
选择渠道<select name="cid" id="cid" title="渠道" class="add-text">
<option value="0">请选择</option>
<option value="1">博客园</option>
</select>
选择包<select name="q_pid" id="q_pid" title="当前资源" class="add-text">
<option value="">请选择资源</option>
</select>
<dd>
</dl>
<dl>
<dt>应用:<input type='radio" name="type" value="2" /></dt>
<dd>
选择应用:<select name="pro" id="pid" title="应用" class="add-text">
<option value="0">请选择</option>
<option value="1">博客园</option>
</select>
选择包: <select name="pid" id="y_pid" title="当前资源" class="add-text">
<option value="">请选择资源</option>
</select>
</dd>
</dl>
<script type="text/javascript">
var showReport = (function(){
function showList(type,date,cid,y_pid,q_pid,pid){
var url = "";
switch(type){
case "1":
url = "/data/xiang/showpk";
break;
case "2":
url = "/data/xiang/show";
break;
default:
url = "/data/xiang/showpk";
break;
}
$.ajax({
url:url,
data:{
date:date,cid:cid,y_pid:y_pid,q_pid:q_pid,pid:pid
},
type:"post",
dataType:"html",
success:function(data){
$("div#divTable").html(data).show(300);
}
});
}
})();
$(function(){
//选择应用时刷新对应的包
$("#pid").change(function(){
var url = "/data/xiang/getpackages";
var sql = "pid";
Ajaxpackages($("#pid").val(),$("#y_pid"),url,sql);//pid,包id,Ajax地址,php页面字段名
});
if($("#pid").val()){
var url = "/data/xiang/getpackages";
var sql = "pid";
Ajaxpackages($("#pid").val(),$("#y_pid"),url,sql);
}
//选择渠道时刷新对应的包
$("#cid").change(function(){
var url = "/data/xiang/getpackages";
var sql = "cid";
Ajaxpackages($("#cid").val(),$("#q_pid"),url,sql);//cid,包id,Ajax地址,php页面字段名
});
if($("#cid").val()){
var url = "/data/xiang/getpackages";
var sql = "cid";
Ajaxpackages($("#cid").val(),$("#q_pid"),url,sql);
}
showReport.showList("1","<?php echo $this -> views['date'];?>");//加载页面时执行
showReport.searchList();
//分页
$("#pages a").live("click",function(e){
var gurl = $(this).attr("href"); //这是a 标签的链接地址,主要用于Page的传值
var type = "1";
$("input[name='type']").each(function(){
if($(this).attr("checked")){
type = $(this).val();
}
});
var url = "";
switch(type){
case "1":
url = "/data/xiang/showpk";
break;
case "2":
url = "/data/xiang/show";
break;
default:
url = "/data/xiang/showpk";
break;
}
var date = $("input[name='date']").val();
var cid = $("#cid").val();
var q_pid = $("#q_pid").val();
var y_pid = $("#y_pid").val();
var pid = $("#pid").val();
$.ajax({
data:{
date:date,cid:cid,y_pid:y_pid,q_pid:q_pid,pid:pid
},
type:"post",
dataType:"html",
success:function(data){
$("div#divTable").html(data).show(300);
}
});
e.preventDefault();//去掉a标签的单击默认的操作
})
});
function Ajaxpackages(pid,pk,url,sql){
$.ajax({
url:url,
type:"post",
data:{pid:pid,v:new Date().getTime(),sql:sql},
success:function(data){
if(data){
var jsondata=eval(data);
var len = jsondata.length;
var selectContent = "<option value=''>资源包</option>";
for(var i=0;i<len;i++){
if(jsondata[i].acc_name){
selectContent += '<option value="'+jsondata[i].acc_id+'">'+jsondata[i].acc_name+'</option> ';
}
}
}else{
selectContent = '<option value="">--没有对应的包--</option> ';
}
pk.html(selectContent);
}
});
}
</script>
zendFream 中的用到了Ajax(其中有搜索)分页的更多相关文章
- 页面中的删除确认(ajax)、输入框中确认信息是否可用(ajax)的jquery代码
1.页面中的删除确认(ajax) <%@ page language="java" contentType="text/html; charset=UTF-8&qu ...
- laravel中form表单,ajax传值没反应
laravel中form表单,ajax传值没反应时,可能是令牌有问题. form中添加: {{csrf_token()}} ajax中添加: data: {'page': page, '_token' ...
- thinkphp ajax 无刷新分页效果的实现
思路:先做出传统分页效果,然后重新复制一份Page.class.php类,对它进行修改,把js中的函数传到page类中,把上一页.下一页.首页.尾页.链接页中的url地址改成js控制的函数,模板页面中 ...
- thinkphp下实现ajax无刷新分页
1.前言 作为一名php程序员,我们开发网站主要就是为了客户从客户端进行体验,在这里,thinkphp框架自带的分页类是每次翻页都要刷新一下整个页面,这种翻页的用户体验显然是不太理想的,我们希望每次翻 ...
- PHP 实例 - AJAX 实时搜索-AJAX Live Search
PHP 实例 - AJAX 实时搜索 AJAX 可为用户提供更友好.交互性更强的搜索体验. AJAX Live Search 在下面的实例中,我们将演示一个实时的搜索,在您键入数据的同时即可得到搜索结 ...
- ajax 无刷新分页
//ajax 无刷新分页1.前台要做的 滑动时 当前page+1,通过page ajax请求后台接口获取数据将数据进行拼装;2.后台要做的 做分页接口返回json数据前台判断触发请求条件: var p ...
- 转:SQL SERVER数据库中实现快速的数据提取和数据分页
探讨如何在有着1000万条数据的MS SQL SERVER数据库中实现快速的数据提取和数据分页.以下代码说明了我们实例中数据库的“红头文件”一表的部分数据结构: CREATE TABLE [dbo]. ...
- Yii 框架ajax搜索分页
要想实现ajax搜索分页 其实很简单 第一步:在 Yii 框架自带的搜索和分页正常运行的情况下,在视图层
- 关于Ajax无刷新分页技术的一些研究 c#
关于Ajax无刷新分页技术的一些研究 c# 小弟新手,求大神有更好的解决方案,指教下~ 以前做项目,用过GridView的刷新分页,也用过EasyUI的封装好的分页技术,最近在老项目的基础上加新功能, ...
随机推荐
- 【转】Struts2解决表单重复提交问题
用户重复提交表单在某些场合将会造成非常严重的后果.例如,在使用信用卡进行在线支付的时候,如果服务器的响应速度太慢,用户有可能会多次点击提交按钮,而这可能导致那张信用卡上的金额被消费了多次.因此,重复提 ...
- Jmeter之csv、用户自定义变量以及Query Type分析(八)
很多童鞋不知道对于Jmeter的Query Type 不知道选哪个,为什么选,怎么选! 下面这边做个简单的分析, 那么首先什么是CSV Data Set Config,有什么用呢? CSV Data ...
- Portlet简述
一.Portlet是什么? Portlet是基于java的web组件,由portlet容器管理,并由容器处理请求,生产动态内容.Portals使用portlets作为可插拔用户接口组件,提供信息系统的 ...
- loopback 02
数据库连接操作,以mongodb为例 安装loopback-connector-mongodb 修改datasources.json //例子 { "db": { "na ...
- CentOS下vm虚拟机桥接联网
CentOS下vm虚拟机桥接联网 vm虚拟机下的桥接联网相当于虚拟机是一个独立的主机,直接与外网相连,这是比较好的连接方式,这样外网的机子就可以直接访问到虚拟机了. 首先虚拟机的联网方式设置为 ...
- Delphi 包的设计思想及它与PAS、BPL、DCU、DLL、OXC的关系。
DCP ,BPL分别是什么文件,起什么作用?你在DELPHI中建立一个package然后保存一下,看看. bpl和Dll比较相似.只是BPL是BORLAND自己弄出来的东西!!!调用也和调用DLL相似 ...
- 转:delphi 删除指定文件夹下所有文件
function TFtpContentThd.DeleteDirectory(NowPath: string): Boolean; var search: TSearchRec; ret: inte ...
- Python基础2- Hello,world
第一个程序Hello,world! 交互式编程:在终端窗口中输入:python回车后直接进入python交互模式,然后在提示符>>>后面输入:print 'Hello,world!' ...
- Python: 常用list, string处理功能
#1. keep strings in double quote as one word when split string to words #e.g. str = ‘a b "is si ...
- Java NIO非阻塞理论学习
Java NIO和阻塞IO的区别: 阻塞I/O在调用InputStream.read()方法时是阻塞的,它会一直等到数据到来时(或超时)才会返回:同样,在调用ServerSocket.accept() ...