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">& ...
随机推荐
- Maven编译可执行jar
打包: 第一种情况:独立项目,且无第三方依赖包 这种情况下,我们需要maven的maven-jar-plugin插件来帮我们打包.请在项目pom.xml中的plugin配置处加入如下内 <plu ...
- Python入门学习
1.访问www.python.org/download下载并安装Python3版本 2.命令行输入python启动交互式命令shell,>>>代表当前行用户的输入 3.基本算数运算: ...
- es6--(二)变量的解构赋值
1.数组的解构赋值 //数组解析 let [a,b,c] = [1,2,3]; //a=1;b=2;c=3 //嵌套数组 let [a,[b,c]] = [1,[2,3]];//a=1;b=2;c=3 ...
- python ast
import ast print ast.literal_eval('[1, 2, 3]')print eval("2 + 3 * len('hello')") == 17prin ...
- Delphi @ # $ 特殊字符含义
^: 指针 @: 取址 #: 十进制符 $: 十六进制符
- HTML表格标记
- hdu 1217 Arbitrage
Flody多源最短路 #include<cstdio> #include<cstring> #include<string> #include<cmath&g ...
- 在家用机上搭建 Git https 服务器
今天主要叙述在家里台式机的虚拟机上搭建支持 https 的 ubuntu git 服务器. 实际上,从一个用户请求家里 git 服务器代码,最终完成代码的传输,主要是通过以下的过程: 首先,从外界寻找 ...
- [妙味Ajax]第三课:AJAX跨域解决方案:JSONP
知识点总结: JSONP(JSON with Padding): 1.script标签 2.用script标签加载资源是没有跨域问题的 在资源加载进来之前定义好一个函数,这个函数接收一个参数(数据), ...
- [妙味JS基础]第二课:for应用、this关键字
知识点总结 getElementsByTagName(动态方法) 与 getElementById(静态方法) 的区别 1.ID前面只能跟document,不能跟其他元素,比如:document.ge ...