PHP关于表单提交 后 post get分页
- //简单加密字符串函数
- function str_encode($str){
- $t = implode("",unpack("H*",$str));
- return base64_encode($t);
- }
- //简单解密字符串函数
- function str_decrypt($str){
- $t = base64_decode($str);
- $s = "";
- for($i=0;$i <strlen($t);$i+=4)
- $s .= @pack("H4",substr($t,$i,4));
- return $s;
- }
- //分页函数
- function multi($num, $perpage, $curpage, $mpurl, $maxpages = 0, $page = 10, $autogoto = true, $simple = false) {
- $multipage = '';
- $mpurl .= strpos($mpurl, '?') ? '&' : '?';
- $realpages = 1;
- if ($num > $perpage) {
- $offset = 2;
- $realpages = @ceil($num / $perpage);
- $pages = $maxpages && $maxpages < $realpages ? $maxpages : $realpages;
- if ($page > $pages) {
- $from = 1;
- $to = $pages;
- } else {
- $from = $curpage - $offset;
- $to = $from + $page - 1;
- if ($from < 1) {
- $to = $curpage + 1 - $from;
- $from = 1;
- if ($to - $from < $page) {
- $to = $page;
- }
- } elseif ($to > $pages) {
- $from = $pages - $page + 1;
- $to = $pages;
- }
- }
- $multipage = ($curpage - $offset > 1 && $pages > $page ? '<a href="' . $mpurl . 'page=1" class="first"' . $ajaxtarget . '>1 ...</a>' : '') .
- ($curpage > 1 && !$simple ? '<a href="' . $mpurl . 'page=' . ($curpage - 1) . '" class="prev"' . $ajaxtarget . '>‹‹</a>' : '');
- for($i = $from; $i <= $to; $i++) {
- $multipage .= $i == $curpage ? '<strong>' . $i . '</strong>' :
- '<a href="' . $mpurl . 'page=' . $i . ($ajaxtarget && $i == $pages && $autogoto ? '#' : '') . '"' . $ajaxtarget . '>' . $i . '</a>';
- }
- $multipage .= ($curpage < $pages && !$simple ? '<a href="' . $mpurl . 'page=' . ($curpage + 1) . '" class="next"' . $ajaxtarget . '>››</a>' : '') .
- ($to < $pages ? '<a href="' . $mpurl . 'page=' . $pages . '" class="last"' . $ajaxtarget . '>... ' . $realpages . '</a>' : '') .
- (!$simple && $pages > $page && !$ajaxtarget ? '<kbd><input type="text" name="custompage" size="3" onkeydown="if(event.keyCode==13) {window.location=\'' . $mpurl . 'page=\'+this.value; return false;}" /></kbd>' : '');
- $multipage = $multipage ? '</div><DIV id="quicklinks">' . (!$simple ? '<em> ' . $num . ' </em>' : '') . $multipage . '</div>' : '';
- }
- $maxpage = $realpages;
- return $multipage;
- }
上面的函数是在网上找的原分页函数,此函数用于GET方法的页面直接使用就OK了,用于POST页面,只需要在函数内的页面链接<A>标签里增加一个onclick事件函数,如下:<A href="#" onclick="gotoPage(1);">第一页</A>,然后在页面里增加一个javascript方法见下:
- <script language="javascript">
- //函数跳转到指定页面
- function gotoPage(page)
- {
- document.getElementById("page").value = page; //隐藏表单的页控件
- document.getElementById("searchForm").submit();
- }
- //函数:回来第1页
- function gotoFirstPage()
- {
- document.getElementById("page").value = 1; //隐藏表单的页控件
- }
- </script>
- <!-- 表单参考如下 -->
- <form name="searchForm" id="searchForm" method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
- <!-- 下面是个隐藏页面号码值控件 -->
- <input type="hidden" name="page" id="page" size=30 value="<?php echo $page;?>" />
- <!-- 下面是个查找条件值控件 -->
- <input type="text" name="photoname" id="photoname" size=30 value="<?php echo $photoname;?>" />
- <!-- 提交控钮,注意id和name不要把值设成"submit",我将其改为"submit1" -->
- <!-- 不然在gotoPage()函数里与表单的提交事件submit()有冲突,导至函数不运行 -->
- <!-- 这个提交按钮还增加了一个单击事件gotoFirstPage() -->
- <!-- 作用就是无论何时当你点击查找按钮后页面都会是第1页,其实就是将隐藏的页面控制值设为1 -->
- <input name="submit1" id="submit1" onclick="gotoFirstPage()" type="submit" value="查 找" size=30 />
- </form>
- <!-- 当然这样改了后,还应该改改原来的分页函数,1.增页分页码链接的单击事件 -->
- <!-- 2.让<A>标签href的值为"#",作用当然就是不要<A>标签点击后,页面跳转,只让单击事件来提交表单取得指定页面 -->
- <!-- 我尽量在少改动原函数的情况下,只在href后面增加"#?",因为这个原函数在href后面带有"?"号,实际我只要在在最前面增加一个#号就OK,原函数修改如下 -->
- <?php
- //分页函数
- function multi($num, $perpage, $curpage, $mpurl, $maxpages = 0, $page = 10, $autogoto = true, $simple = false) {
- $multipage = '';
- $mpurl .= strpos($mpurl, '?') ? '&' : '?';
- $realpages = 1;
- if ($num > $perpage) {
- $offset = 2;
- $realpages = @ceil($num / $perpage);
- $pages = $maxpages && $maxpages < $realpages ? $maxpages : $realpages;
- if ($page > $pages) {
- $from = 1;
- $to = $pages;
- } else {
- $from = $curpage - $offset;
- $to = $from + $page - 1;
- if ($from < 1) {
- $to = $curpage + 1 - $from;
- $from = 1;
- if ($to - $from < $page) {
- $to = $page;
- }
- } elseif ($to > $pages) {
- $from = $pages - $page + 1;
- $to = $pages;
- }
- }
- //注意下面href后面我增加了一个#号,让链接失效,在后面增加onclick函数
- $multipage = ($curpage - $offset > 1 && $pages > $page ? '<a href="#' . $mpurl . 'page=1" onclick="gotoPage(1);" class="first"' . $ajaxtarget . '>1 ...</a>' : '') .
- ($curpage > 1 && !$simple ? '<a href="#' . $mpurl . 'page=' . ($curpage - 1) . '" onclick="gotoPage(' . ($curpage - 1) . ');" class="prev"' . $ajaxtarget . '>‹‹</a>' : '');
- for($i = $from; $i <= $to; $i++) {
- $multipage .= $i == $curpage ? '<strong>' . $i . '</strong>' :
- '<a href="#' . $mpurl . 'page=' . $i . ($ajaxtarget && $i == $pages && $autogoto ? '#' : '') . '"' . $ajaxtarget . ' onclick="gotoPage(' . $i .');" target="_blank" target="_blank">' . $i . '</a>';
- }
- $multipage .= ($curpage < $pages && !$simple ? '<a href="#' . $mpurl . 'page=' . ($curpage + 1) . '" onclick="gotoPage(' . ($curpage + 1) . ');" class="next"' . $ajaxtarget . '>››</a>' : '') .
- ($to < $pages ? '<a href="#' . $mpurl . 'page=' . $pages . '" onclick="gotoPage(${pages});" class="last"' . $ajaxtarget . '>... ' . $realpages . '</a>' : '') .
- //下面这一行注释掉,改了一下超过10页,可以手动输入页码跳转到指定页面函数
- // (!$simple && $pages > $page && !$ajaxtarget ? '<kbd><input type="text" name="custompage" size="3" onkeydown="if(event.keyCode==13) {window.location=\'' . $mpurl . 'page=\'+this.value; return false;}" /></kbd>' : '');
- (!$simple && $pages > $page && !$ajaxtarget ? '<kbd><input type="text" name="custompage" size="3" onkeydown="if(event.keyCode==13) {gotoPage(this.value);}" /></kbd>' : '');
- $multipage = $multipage ? '</div><DIV id="quicklinks">' . (!$simple ? '<em> ' . $num . ' </em>' : '') . $multipage . '</div>' : '';
- }
- $maxpage = $realpages;
- return $multipage;
- }
- ?>
PHP关于表单提交 后 post get分页的更多相关文章
- AngularJS 表单提交后显示验证信息与失焦后显示验证信息
虽然说AngularJS的实时表单验证非常有用,非常高效方便,但是当用户还没有完成输入时便弹出一个错误提示,这种体验是非常糟糕的. 正常的表单验证逻辑应该是在用户提交表单后或完成当前字段中的输入后,再 ...
- 怎么实现form表单提交后不重新刷新当前页面
怎么实现表单提交后不重新刷新当前页面 如何实现表单提交后不重新刷新当前页面 <form name='form1' id='form1' action='/xbcw/cw/xx_xx.ac ...
- struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input
原文地址:struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input jsp页面 1 function dosearch() {2 if ($(&q ...
- phpcms v9自定义表单提交后返回上一页实现方法
PHPcms v9中提交自定义表单后默认都是回到首页的,是不是感觉很不爽! 接下来,就说下phpcms v9自定义表单提交后返回上一页实现方法. 1.找到这个文件 phpcms\modules\for ...
- DedeCMS实现自定义表单提交后发送指定QQ邮箱法
https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&tn=monline_3_dg&wd=dedecms 邮箱&oq=d ...
- form + iframe 获取表单提交后返回的数据
原理: submit 提交表单没有回调函数,但是可以用iframe来接收返回结果,最后进行格式转换就ok了: 原文地址: http://blog.csdn.net/simeng_1016/articl ...
- flask用宏渲染表单模板时,表单提交后,如果form.validate_on_submit()返回的是false的可能原因
flask用宏渲染表单模板时,表单提交后,提交的内容符合DataRequired()校验, 但是form.validate_on_submit()返回的是False, 原因可能是表单模板中的<f ...
- DedeCMS实现自定义表单提交后发送指定QQ邮箱的方法
如月cruyue在做DedeCMS自定义表单发送邮箱的教程,发现大部分都是在php文件里写死固定字段内容,这样虽然也能实现自定义表单提交后发送指定邮箱,但是很不智能,如月cruyue想要一个我们自定义 ...
- 通过jquery实现form表单提交后不跳转页面,保留当前页面
jquery代码: <script type="text/javascript" src="../js/jquery-1.8.3.min.js">& ...
随机推荐
- Eclipse主题设置
1. 内部编辑区域主题 Eclipse黑色主题包 下载主题包解压到Eclipse安装目录下的dropins目录,重启Eclipse,Windows—>Preferences—>Genera ...
- HDU 3294 Girls' research
题目地址 manacher #include<cstdio> #include<string.h> #include<algorithm> using namesp ...
- linux基础概念
linux的哲学思想 一切皆文件:把几乎所有资源,包括硬件设备都组织为文件格式 由众多单一目的小程序组成:一个程序只实现一个功能,通过组合小程序完成复杂任务 尽量避免跟用户交互:实现脚本编程,以自动完 ...
- 去掉word冗余格式 java正则表达式
word转换html时,会留下很多格式,有些格式并不是我们所需要的,然而这些格式比真正的文章内容还要多,严重影响页面的加载速度,因此就需要找个一个好的解决方案把这些多余的格式个去掉.网上有很多去除wo ...
- 在hadoop 的任务中设置 map数量
试验了一下: 调整mapred-site.xml中mapred.min.split.size的值可以改变map的数量 首先设置了hdfs-site.xml中的dfs.block.size为20M,测试 ...
- SQL 范式(转载)
装载于"http://www.cnblogs.com/KissKnife/ 理论性的东西,往往容易把人人都看得懂的东西写成连鬼都看不懂,近似于主任医生开的药方.从前学范式的时候,把书中得概念 ...
- 第一百零四节,JavaScript时间与日期
JavaScript时间与日期 学习要点: 1.Date类型 2.通用的方法 3.格式化方法 4.组件方法 ECMAScript提供了Date类型来处理时间和日期.Date类型内置一系列获取和设置日期 ...
- Mac下svn的使用
1.从本地导入代码到服务器(第一次初始化导入) 在终端中输入 svn import /Users/apple/Documents/eclipse_workspace/weibo svn://local ...
- nodejs url方法
ulrl方法 url.format(urlObj) //将对象装换成url url.parse(urlStr[, parseQueryString][, slashesDenoteHost]) / ...
- POJ 3122 & 3258 & 3273 #二分
以下三道都是经典二分,道理都差不多,代码就贴在一起了. POJ 3122 POJ 3258 POJ 3273 POJ 3122: #include<iostream> #inc ...