當前位置:首頁 » 編程語言 » php無刷新分頁

php無刷新分頁

發布時間: 2022-06-16 06:49:43

php的變數問題,實現簡單的加減,我的輸出老師有問題,請大神們看看

你這個代碼有問題,

<inputtype=buttonvalue=減onclick=out(<?phpechopre($page)?>)>
<inputtype=buttonvalue=加onclick=out(<?phpechonext1($page)?>)>

這兩行里的$page是打開這個頁面時定義的0,不管你怎麼點,都沒有變過

Ⅱ 有關php+ajax多條件查詢,並且分頁顯示的問題【高分懸賞】

$sql=select * from table where 1=1
四個下拉框 實際上就是四種 檢索條件,在拼接sql的時候分別判斷這四個下拉框是否有值 有的話 $sql.="條件1",
$sql.=「&&條件2」;
以此類推

ajax分頁的時候 需要傳遞的值有 分頁的偏移量,sql語句中的 limit的 開始位置

Ⅲ thinkphp5框架如何實現ajax無刷新分頁呢

那你每次點擊的頁數通過ajax傳入請求的方法里,請求的方法中再通過你的數值對整組數據進行劃分,比如每頁20條,第一頁是limit(0,20),第二頁是limit(20,20),第三頁是limit(40,20),那麼你的頁數乘以20再減去20就是limit()的第一個參數,第二個參數為20。如果每頁為40頁的話則是你的頁數乘以40再減去40;查詢出數據後在返回給ajax,通過jquery刷新便是

Ⅳ ajax無刷新分頁怎麼獲取頁碼的信息

解決了啊,我就是直接在後台用php設置好table以及頁碼連接,然後再傳到js,直接把後台傳來的信息插入到div。我貼出代碼給你看把

Ⅳ html怎麼實現無刷新分頁效果

ajax非同步刷新
這里需要說明一些知識:

1、Ajax 無刷新頁面的好處:提供良好的客戶體驗,通過 Ajax 在後台從資料庫中取得數據並展示,取締了等待載入頁面而出現的空白狀態;
2、那麼,Ajax 無刷新頁面是運行在動態頁面(.php)?還是靜態頁面(.html/.htm/.shtml)?答案是:靜態頁面;
3、實現原理:通過前端 JS 腳本程序與 Ajax 相結合取得從動態頁面返回的數據,並顯示。
好了,下面進行代碼講解:
既然,是運行在靜態頁面上,我們首先先創建一個靜態 HTML 頁面,index.html 的代碼清單如下。
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script type="text/javascript" src="js/ajax.js"></script> <!-- 載入 Ajax 類庫 -->
<title>Ajax 實現無刷新頁面</title>
<style type="text/css">
body {
font-size:12px;
}
</style>
</head>
<body>
<div id="fpage">數據載入中...</div>
</body>
</html>
代碼清單中,我們載入了一個 Ajax 類庫,

在這個靜態頁面中,只會顯示一個「數據載入中....」,並沒有任何數據。這時,我們就需要一個 JS 腳本來實現通過 Ajax 從資料庫中獲取數據。JS 腳本如下:
<script type="text/javascript">
/**
* setPage(url) 根據 url 從 article.php 中獲取數據
* @param int pageNum 頁碼
* @return string
*/
var cache=new Array(); // 緩存變數,當數據被訪問過之後放置在緩存中,加快訪問速度
function setPage(pageNum) {
var fpage = document.getElementById('fpage'); // 獲取 fpage 對象
// 如果緩存中存在數據,那麼直接從緩存中讀取;如果不存在數據,那麼就從資料庫中讀取,並把數據存入緩存
if (typeof(cache[pageNum])=='undefined') {
var ajax = Ajax();
ajax.get('article.php?page='+pageNum, function(data){
fpage.innerHTML = data; // fpage對象的內容是從 article.php 中取來的
cache[pageNum] = data;
})
} else {
fpage.innerHTML = cache[pageNum];
}
}
setPage(1); // 默認執行
</script>
仔細閱讀上面的代碼,您會發現下面現象:

1、setPage(pageNum) 是一個從資料庫中提取數據的 JS 函數介面;
2、Ajax 是通過 article.php 文件來獲取數據;
3、article.php?page=xx,這里的 xx 就是所要取得的頁碼數據,
setPage(1):就是取得第1頁數據;

setPage(2):就是取得第2頁數據;

setPage(100):就是取得第100頁數據;
……
那麼,如何從 article.php 文件中取得數據呢?請看下面代碼清單。
<?php
/**
* $Id: article.php
* author Lee.
* Last modify $Date: 2012-01-21 16:53:05 $
*/
require_once './config.inc.php';
$m = new Model();
$page = new ajaxPage($m->total('article'),20); // $m->total('article') 獲取 article 表的記錄數;10為每頁顯示十條
$result = $m->fetchAll('article', '*', '', '', $page->limit); // 取出數據,^_^,很方便吧
echo '<table align="center" border="1" width="1100" style="border-collapse:collapse;font-size:14px;" bordercolor="#666">';
echo '<caption><h1>華強電子網資訊</h1></caption>';
echo '<tr height="25"><th>ID</th><th>Title</th><th>Author</th><th>Source</th><th>Date</th></tr>';
foreach ($result as $v) {
echo "<tr height='21'><td align='center'>{$v['id']}</td><td>{$v['title']}</td><td align='center'>{$v['author']}</td><td align='center'>{$v['source']}</td><td align='center'>{$v['date']}</td></tr>";
}
echo '<tr><td align="right" colspan="5">'.$page->fpage().'</td></tr>';
echo '</table>';
?>
article.php 中連接的數據是前面文章從華強電子網抓來的資訊數據,因為數據比較大,代碼打包下載中會附加 article.sql 文件,以便大家測試。

靜態頁面 index.html 上顯示的數據就是 article.php 文件中 echo 的代碼。
代碼文件中的 config.inc.php 文件主要就是定義一些常量,比如:資料庫用戶名、資料庫密碼、主機……,資料庫連接類庫(Db.class.php)和資料庫操作類庫(Model.class.php)
這樣,Ajax 無刷新分頁就完成了。程序中還有一個 ajaxPage.class.php 沒有說明,其實,這個 ajaxPage 類庫的使用方法和一般的分頁類庫是一樣的。
即:$page = new ajaxPage(記錄總數, 每頁顯示數);

Ⅵ php怎麼實現無刷新分頁效果

php+ajax實現無刷新分頁實現方法具體如下:
limit 偏移量,長度;
limit 0,7; 第一頁
limit 7,7; 第二頁
limit 14,7; 第三頁
每頁信息條數:7
信息總條數:select count(*) from table
信息總頁數:ceil向上取整(總條數/每頁條數)
1、分頁類具體使用
<?php
class Pagination {
private $total; //數據表中總記錄數
private $listRows; //每頁顯示行數
private $limit; //mysql 資料庫的limit
private $uri; //分頁信息前面的uri地址
private $pageNum; //頁數
private $config = array('header' => "個記錄", "prev" => "【上一頁】", "next" => "【下一頁】", "first" => "【首 頁】", "last" => "【尾 頁】");
private $listNum = 8;
/*
* $total 當前信息總條數
* $listRows 每頁顯示的條數
* $pa 下面的page
http://網址/index.php?page=5
*/
public function __construct($total, $listRows = 10, $pa = "") {
$this->total = $total;
$this->listRows = $listRows;
$this->uri = $this->getUri($pa);
$this->page = !empty($_GET["page"]) ? $_GET["page"] : 1;//不傳入page,則默認顯示首頁
$this->pageNum = ceil($this->total / $this->listRows);
$this->limit = $this->setLimit();
}
//設置每頁顯示的條數
private function setLimit() {
return "Limit " . ($this->page - 1) * $this->listRows . ", {$this->listRows}";
}
//獲得URL地址
private function getUri($pa) {
$url = $_SERVER["REQUEST_URI"] . (strpos($_SERVER["REQUEST_URI"], '?') ? '' : "?") . $pa;
$parse = parse_url($url);
if (isset($parse["query"])) {
parse_str($parse['query'], $params);
unset($params["page"]);
$url = $parse['path'] . '?' . http_build_query($params);
}
return $url;
}
//魔術方法,
public function __get($args) {
if ($args == "limit")
return $this->limit;
else
return null;
}
//頁面開始的條數
private function start() {
if ($this->total == 0)
return 0;
else
return ($this->page - 1) * $this->listRows + 1;
}
//頁面結束的條數
private function end() {
return min($this->page * $this->listRows, $this->total);
}
/*設置首頁*/
private function first() {
$html = "";
if ($this->page == 1)
$html.=' '.$this->config["first"].' ';
else
$html.=" <a href='javascript:void(0)' onclick='showPage(\"{$this->uri}&page=1\")'>{$this->config["first"]}</a> ";
//$html.=" <a href='{$this->uri}&page=1'>{$this->config["first"]}</a> ";
return $html;
}
/*設置上一頁*/
private function prev() {
$html = "";
if ($this->page == 1)
$html.=' '.$this->config["prev"].' ';
else
$html.=" <a href='javascript:void(0)' onclick='showPage(\"{$this->uri}&page=" . ($this->page - 1) . "\")'>{$this->config["prev"]}</a> ";
//$html.=" <a href='{$this->uri}&page=".($this->page-1)."'>{$this->config["prev"]}</a> ";
return $html;
}
//頁碼列表【首頁】【2】【3】…………【尾頁】
private function pageList() {
$linkPage = "";
$inum = floor($this->listNum / 2);
for ($i = $inum; $i >= 1; $i--) {
$page = $this->page - $i;
if ($page < 1)
continue;
$linkPage.=" <a href='javascript:void(0)' onclick='showPage(\"{$this->uri}&page={$page}\")'>{$page}</a> ";
}
$linkPage.=" {$this->page} ";
for ($i = 1; $i <= $inum; $i++) {
$page = $this->page + $i;
if ($page <= $this->pageNum)
$linkPage.=" <a href='javascript:void(0)' onclick='showPage(\"{$this->uri}&page={$page}\")'>{$page}</a> ";
else
break;
}
return $linkPage;
}
/*設置下一頁*/
private function next() {
$html = "";
if ($this->page == $this->pageNum)
$html.=' '.$this->config["next"].' ';
else
$html.=" <a href='javascript:void(0)' onclick='showPage(\"{$this->uri}&page=" . ($this->page + 1) . "\")'>{$this->config["next"]}</a> ";
//$html.=" <a href='{$this->uri}&page=".($this->page + 1)."'>{$this->config["next"]}</a> ";
return $html;
}
/*設置尾頁*/
private function last() {
$html = "";
if ($this->page == $this->pageNum)
$html.=' '.$this->config["last"].' ';
else
$html.=" <a href='javascript:void(0)' onclick='showPage(\"{$this->uri}&page=" . ($this->pageNum) . "\")'>{$this->config["last"]}</a> ";
//$html.=" <a href='{$this->uri}&page=.(this->pageNum).'>{$this->config["last"]}</a> ";
return $html;
}
/*設置頁面跳轉*/
private function goPage() {
return
' <input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>' . $this->pageNum . ')?' . $this->pageNum . ':this.value;showPage(\'' . $this->uri . '&page=\'+page+\'\')}" value="' . $this->page . '" style="width:25px">
<input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>' . $this->pageNum . ')?' . $this->pageNum . ':this.previousSibling.value;showPage(\'' . $this->uri . '&page=\'+page+\'\')"> ';
}
//頁面列表配置選項
function fpage($display = array(0, 1, 2, 3, 4, 5, 6, 7, 8)) {
$html[0] = " 共有<b>{$this->total}</b>{$this->config["header"]} ";
$html[1] = " 每頁顯示<b>" . ($this->end() - $this->start() + 1) . "</b>條,本頁<b>{$this->start()}-{$this->end()}</b>條 ";
$html[2] = " <b>{$this->page}/{$this->pageNum}</b>頁 ";
$html[3] = $this->first();
$html[4] = $this->prev();
$html[5] = $this->pageList();
$html[6] = $this->next();
$html[7] = $this->last();
$html[8] = $this->goPage();
$fpage = '';
foreach ($display as $index) {
$fpage.=$html[$index];
}
return $fpage;
}
}
2 數據顯示
<?php
//鏈接資料庫
//獲得具體信息
//分頁顯示
header("content-type:text/html;charset=utf-8");
$link = mysql_connect('localhost','root','111111');
mysql_select_db('shop', $link);
mysql_query("set names utf8");
$css = <<<eof
<style type="text/css">
table {border:1px solid black; width:700px; margin:auto; border-collapse:collapse;}
td {border:1px solid black; }
</style>
eof;
echo $css;
echo "
<table>
<tr><td>序號</td><td>名稱</td><td>數量</td><td>價格</td><td>時間</td></tr>
";
//1 引入分頁類
include "./Pagination.php";
//2. 獲得信息總條數
$sql = "select * from sw_goods";
$qry = mysql_query($sql);
$total = mysql_num_rows($qry);
$per = 7;
//3. 實例化分頁類對象
$page_obj = new Pagination($total,$per);
//4. 拼裝sql語句,獲得每頁信息
//利用page_obj實現limit的靈活設置
//$page_obj -> limit;
$sqla = "select * from sw_goods ".$page_obj->limit;
$qrya = mysql_query($sqla);
//5. 獲得頁面列表
$pagelist = $page_obj -> fpage(array(3,4,5,6,7,8));
$i=1;
while($rsta = mysql_fetch_assoc($qrya)){
echo "<tr>";
echo "<td>".$i++."</td>";
echo "<td>".$rsta['goods_name']."</td>";
echo "<td>".$rsta['goods_number']."</td>";
echo "<td>".$rsta['goods_price']."</td>";
echo "<td>".date("Y-m-d H:i:s",$rsta['goods_create_time'])."</td>";
echo "</tr>";
}
echo "<tr><td colspan=5>".$pagelist."</td></tr>";
echo "</table>";
3 ajax無刷新分頁實現
open(『get','http://網址/index.php?page=2')
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>新建網頁</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="description" content="" />
<meta name="keywords" content="" />
<script type="text/javascript">
//獲得分頁信息ajax函數
function showPage(myurl){
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.readyState==4){
var rst = document.getElementById("result");
rst.innerHTML = xhr.responseText;
}
}
xhr.open("get",myurl);
xhr.send(null);
}
window.onload = function(){
showPage("./data1.php"); //獲得分頁信息
//showPage("./data.php?page=2");
}
</script>
<style type="text/css">
</style>
</head>
<body>
<h2>ajax無刷新分頁效果</h2>
<div id="result"></div>
</body>
</html>
<script type="text/javascript">
document.write(new Date()+"<br />");
document.write(new Date()+"<br />");
document.write(new Date()+"<br />");
document.write(new Date()+"<br />");
</script>

Ⅶ dedecms文章列表實現 點擊載入更多 ajax無刷新分頁

這個思路很簡單做起來比較麻煩在模板中做一個載入的按鈕,點擊後使用ajax去請求數據。請求到數據後將數據添加到網頁對應的容器中。請求的路徑你在plus目錄下新建一個php文件,也就是dedecms的插件目錄,內容參開如下(我的瀑布流獲取數據插件):require_once(dirname(__FILE__)."/../include/common.inc.php");//$t1=ExecTime();$page=isset($_GET['page'])?$_GET['page']:1;$per=isset($_GET['per'])?$_GET['per']:1;$limit=(($page-1)*$per).",".$per;$selquery="SELECT*FROM`#@__archives`wherechannel=2limit".$limit;$dsql->SetQuery($selquery);$dsql->Execute();while($row=$dsql->GetArray()){$arcurl=GetOneArchive($row['id']);$arcurl=$arcurl['arcurl'];$count=Getimgnum($row['id']);$img=thumbImg($row['litpic'],235,0);$title=$row['title'];echo"$count張$title";}輸出內容就直接使用你的模板中的列表部分,數據在插件里直接填充。每次獲取三條修改sql的limit即可

Ⅷ (php ajax)頁面中的一個排行榜有分頁功能,點擊下一頁實現排行榜局部刷新,怎麼實現

可以把分頁顯示的那個模塊用<iframe>標簽,這樣只會局部刷新分頁點擊下一頁顯示的地方保持其他地方不變。

Ⅸ thinkPHP3.2.3如何利用ajax進行無刷新分頁呢

本質是和正常的刷新一樣的,都是同一個模塊。花費時間的地方就是把讀取到的數據,按照頁面的布局來拼接返回的數據,操作DOM而已。

Ⅹ 誰給我講下ajax+php無刷新分頁原理

ajax 是一個js腳本。或者用jquery裡面的ajax
如果你要驗證用戶名。你可以在你的input 屬性裡面加上 onchange=「調用函數」
調用函數就是ajax的代碼。
ajax是這樣完成工作的,
首先發送請求到你指定的頁面比如abc.php(附帶你設置的post或者get),
abc.php響應成功後,執行它裡面的代碼去處理你傳遞過來的參數。如果存在這個用戶。然後返回一個值或者函數 如果不存在也會返回一個值或者函數,你要自己去設置。
然後ajax把這個返回的值或者函數進行處理,比如顯示它,或者調用函數禁用提交按鈕。

熱點內容
linux驅動開發教程 發布:2024-05-17 17:19:52 瀏覽:500
抖音中秋節視頻腳本 發布:2024-05-17 17:19:51 瀏覽:193
快遞櫃為什麼用安卓系統 發布:2024-05-17 17:17:18 瀏覽:906
電腦配置光纖介面怎麼標注 發布:2024-05-17 17:06:56 瀏覽:976
如何用方向鍵控制安卓機 發布:2024-05-17 16:38:11 瀏覽:198
雨田系統源碼 發布:2024-05-17 16:28:06 瀏覽:586
新手直播腳本 發布:2024-05-17 16:27:25 瀏覽:847
python雙引號單引號 發布:2024-05-17 16:19:31 瀏覽:948
0xxc語言 發布:2024-05-17 16:17:40 瀏覽:700
php與java的區別 發布:2024-05-17 16:12:48 瀏覽:340