thinkPHP3.2.3結(jié)合Laypage實(shí)現(xiàn)的分頁功能示例
本文實(shí)例講述了thinkPHP3.2.3結(jié)合Laypage實(shí)現(xiàn)的分頁功能。分享給大家供大家參考,具體如下:
控制器
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
/**
*@brief 查詢
****/
public function index(){
$choose = I('choose','-6');
$c['easy_hard'] = $choose;
$type=I('typeid','');
$nowpage=I('page',1);
if($type == '')
{
if($choose == -6)
{
$totalpage=ceil((D('data')->count())/10);
$infos=D('data')->limit(($nowpage-1)*10,10)->select();
}else{
$totalpage=ceil((D('data')->where($c)->count())/10);
$infos=D('data')->where($c)->limit(($nowpage-1)*10,10)->select();
}
}else{
if($choose == -6)
{
$map['data'] = array('like',"%$type%");
$totalpage=ceil((D('data')->where($map)->count())/10);
$infos=D('data')->where($map)->limit(($nowpage-1)*10,10)->select();
}else{
$map['data'] = array('like',"%$type%");
$totalpage=ceil((D('data')->where($map)->where($c)->count())/10);
$infos=D('data')->where($map)->where($c)->limit(($nowpage-1)*10,10)->select();
}
}
$this->assign('type',$type);
$this->assign('choose',$choose);
$this->assign("totalpage",$totalpage);
$this->assign("infos",$infos);
$this -> display();
}
}
視圖層
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Think Demo</title>
<script type="text/javascript" src="__PUBLIC__/jquery-1.11.1/jquery.min.js"></script>
<script type="text/javascript" src="__PUBLIC__/jquery-1.11.1/jquery.js"></script>
<script type="text/javascript" src="__PUBLIC__/layer/layer.js"></script>
<script type="text/javascript" src="__PUBLIC__/laypage/laypage.js"></script>
</head>
<body>
<div>
<select name="" id="slc1" onchange="return choose()">
<option value="-6" <if condition="$choose eq -6 "> selected </if> >全部</option>
<option value="0" <if condition="$choose eq 0 "> selected </if> >簡單</option>
<option value="1" <if condition="$choose eq 1 "> selected </if> >一般</option>
</select>
<input type="text" value="<if condition="$type neq '' "> {$type} </if>" id="type"><button id="sou">搜索</button>
</div>
<br>
<table border="1" width="500" height="150" >
<tr>
<th>ID</th>
<th>語言</th>
<th>難易程度</th>
<th>操作</th>
</tr>
<volist name="infos" id="vo">
<tr>
<th>{$vo.id}</th>
<th>{$vo.data}</th>
<th>
<if condition="$vo.easy_hard eq '0'">簡單
<else />一般
</if>
</th>
<th>
<a href="javascript:;" rel="external nofollow" rel="external nofollow" onclick="return del({$vo.id});">刪除</a>
<a href="javascript:;" rel="external nofollow" rel="external nofollow" onclick="return edit({$vo.id});">修改</a>
</th>
</tr>
</volist>
</table>
<div style="margin-top:15px; text-align:center;" id="page11"></div>
<button onclick="return add_()"> 添加 </button> <br />
<script type="text/javascript">
function choose()
{
var type=$("#type").val();
var checkValue=$("#slc1").val();
window.location.href="?typeid=" rel="external nofollow" rel="external nofollow" +type+"&choose="+checkValue;
}
$("#sou").bind("click",function(event){
var type=$("#type").val();//獲取假設(shè)的搜索條件值
var checkValue=$("#slc1").val();
window.location.href="?typeid=" rel="external nofollow" rel="external nofollow" +type+'&choose='+checkValue;
});
$(function(){
laypage({
cont: 'page11',
pages: {$totalpage}, //假設(shè)我們獲取到的是18(后端計(jì)算完總頁數(shù)后將總頁數(shù)值傳過來,放在這里即可(類似{$totalpage})).
curr: function(){ //通過url獲取當(dāng)前頁,也可以同上(pages)方式獲取
var page = location.search.match(/page=(\d+)/);
return page ? page[1] : 1;//如果沒有頁數(shù)顯示時(shí),默認(rèn)是第一頁
}(),
jump: function(e, first){ //觸發(fā)分頁后的回調(diào)
if(!first){ //一定要加此判斷,否則初始時(shí)會(huì)無限刷新
location.href=setParam("page",e.curr);
}
}
});
});
function setParam(param,value){
var query = location.search.substring(1);
var p = new RegExp("(^|)" + param + "=([^&]*)(|$)");
if(p.test(query)){
//query = query.replace(p,"$1="+value);
var firstParam=query.split(param)[0];
var secondParam=query.split(param)[1];
if(secondParam.indexOf("&")>-1){
var lastPraam=secondParam.split("&")[1];
return '?'+firstParam+'&'+param+'='+value+'&'+lastPraam;
}else{
if(firstParam){
return '?'+firstParam+''+param+'='+value;
}else{
return '?'+param+'='+value;
}
}
}else{
if(query == ''){
return '?'+param+'='+value;
}else{
return '?'+query+'&'+param+'='+value;
}
}
}
</script>
</body>
</html>
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
- laypage.js分頁插件使用方法詳解
- layui2.0使用table+laypage實(shí)現(xiàn)真分頁
- 基于layPage插件實(shí)現(xiàn)兩種分頁方式淺析
- thinkPHP5使用laypage分頁插件實(shí)現(xiàn)列表分頁功能
- 基于LayUI分頁和LayUI laypage分頁的使用示例
- VUEJS實(shí)戰(zhàn)之利用laypage插件實(shí)現(xiàn)分頁(3)
- laypage分頁控件使用實(shí)例詳解
- js多功能分頁組件layPage使用方法詳解
- laypage前端分頁插件實(shí)現(xiàn)ajax異步分頁
- laypage+SpringMVC實(shí)現(xiàn)后端分頁
相關(guān)文章
Zend Framework創(chuàng)建自己的動(dòng)作助手詳解
這篇文章主要介紹了Zend Framework創(chuàng)建自己的動(dòng)作助手實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了基于助手的抽象基類Zend_Controller_Action_Helper_Abstract實(shí)現(xiàn)自定義動(dòng)作助手的相關(guān)技巧,需要的朋友可以參考下2016-03-03
php開發(fā)最強(qiáng)大的IDE編輯的phpstorm 2020.2配置Xdebug調(diào)試的詳細(xì)教程
這篇文章主要介紹了php開發(fā)最強(qiáng)大的IDE編輯的phpstorm 2020.2配置Xdebug調(diào)試,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
淺析echo(),print(),print_r(),return之間的區(qū)別
這篇文章主要是對echo(),print(),print_r(),return之間的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-11-11
WordPress中訪客登陸實(shí)現(xiàn)郵件提醒的PHP腳本實(shí)例分享
這篇文章主要介紹了WordPress中訪客登陸實(shí)現(xiàn)郵件提醒的PHP腳本實(shí)例分享,類似于社交網(wǎng)站的異地IP登陸提醒,不過IP所在地顯示的實(shí)現(xiàn)并沒有在本文介紹范圍中,需要的朋友可以參考下2015-12-12

