控制器里面的search方法:
public function search(){ import("@.ORG.Page"); $list = D('Blog'); $keyword = trim($this->_post('keyword','htmlspecialchars')); $sql = "SELECT b.*, a.`content`, u.`username` FROM blog b LEFT JOIN blog_attribute a ON a.`blog_id`=b.`id` LEFT JOIN user u ON u.`id`=b.`user_id` "; if(!empty($keyword)){ $sql .= " WHERE b.`title` LIKE '%{$keyword}%' OR a.`content` LIKE '%{$keyword}%'"; } $count = count($list->query($sql)); $Page = new Page($count,2); $firstRow = $Page->firstRow; $listRows = $Page->listRows; $this->data = $list->searchBlog($sql,$firstRow,$listRows); $xxx['data'] = $this->data; $page = $Page->show(); $xxx['page'] = $page; //$this->data['page'] = $page; //$this->assign("page",$page); //var_dump(urldecode(json_encode($this->data))); $this->show(urldecode(json_encode($xxx))); }
列表页的代码:
<import type="css" file="Css.rightContent" /><import type="js" file="js.jquery_min" /><script type="text/javascript">$(document).ready(function(){ $("button").click(function(){ var keyword = $(this).parent("div").children("input").val(); $.ajax({ url: "{:U('Blog/search')}", type: "POST", data: {"keyword":keyword}, error:function(e){ alert("查询出错!"); }, success:function(data){ $("#cell_tb_list").empty(); if(data != ""){ data = eval('('+data+')'); //alert(data.data.length); var layer = "<table class=\"has_checkbox\">"; layer += "<colgroup>"; layer += "<col class=\"col1\">"; layer += "<col class=\"col2\">"; layer += "<col class=\"col3\">"; layer += "<col class=\"col4\">"; layer += "<col class=\"col5\">"; layer += "</colgroup>"; layer += "<tbody>"; layer += "<tr class=\"hoverout\">"; layer += "<th class=\"td2\">发布人</th>"; layer += "<th class=\"td2\">博客标题</th>"; layer += "<th class=\"td2\">发布时间</th>"; layer += "<th class=\"td2\">更新时间</th>"; layer += "<th class=\"td2\">操作</th>"; layer += "</tr>"; for(var i=0;i<data.data.length;i++){ layer += "<tr id=\"testhere\">"; layer += "<td>"+data.data[i].username+"</td>"; layer += "<td>"+data.data[i].title+"</td>"; layer += "<td>"+data.data[i].create_time+"</td>"; layer += "<td>"+data.data[i].update_time+"</td>"; layer += "<td>修改|删除</td>"; layer += "</tr>"; } layer += "<tr class=\"hoverout\" ><td colspan=\"6\" id=\"td_click\" style=\"text-align:right;\">"+data.page+"</td></tr>"; layer += "</tbody>"; layer += "</table>"; // var layer = "<h1 id="data-create-time">"+data[0].create_time+"</h1>"; $("#cell_tb_list").append(layer); }else{ alert("no"); } } }); });});</script><div id="stage" class="content"> <div id="main"> <div class="title"> <div class="m_bg">博客列表页</div> </div> <div class="mainContent"> <div class="main_content"> <div class="location"> <div class="location_main item"> <div class="search_main"> <!--<form action="__URL__/search" id="search_form" method="post">--> <input type="text" id="query_input" class="search input_txt" name="query_keyword"> <button class="btn" title="Submit Search" type="submit"></button> <!--</form>--> </div> </div> </div> <div class="cell_tb_list" id="cell_tb_list"></div> </div> </div> </div></div>
个人的想法是点了列表页之后出来的就是一个搜索框,填写搜索信息之后在当前页面显示搜索到的信息,然后加上分页。分页的各个页面都是在当前页面下显示。
这样的话,列表第一页是现实正常的 ,但是点击了后面的分页之后就出现了
我是新手,这方面不是很懂,希望大家帮忙看看怎么修改才能是分页能够正常。分页类就是使用的thinkphp原来的,稍微有点样式的小改动。
回复讨论(解决方案)
没人看的吗
是用ajax获取服务器端的数据。你点后面的分页看看返回的json数据。或者可以在后台直接调试,给几个参数,在服务器端看看数据是不是正常。
是用ajax获取服务器端的数据。你点后面的分页看看返回的json数据。或者可以在后台直接调试,给几个参数,在服务器端看看数据是不是正常。
我的最后一张图就是点击第二页出来的结果,返回的数据就是第二页的数据
你要修改page类才可以点下一页的,否则就输出了春json格式
第二页返回的数据不正常吗,最好是在后端调试一下。
会不会跟你的那个分隔符有关系?试试把{}换成
http://dadaboke.com直接使用thinkphp框架中分也类就好了,都用好多次,蛮好用的,自己也可以改样式。
这个好像没办法,因为你是ajax提交返回的,除了改page类,还有一个补救办法,
$(function(){ $('.page a').click(function(){ $.get($(this).attr('href'),function(data){ $('#index_content').html(data); }) return false; }) })
得到data后你再按你的格式处理下,你可以试一下,是可以的
这个应该很好实现吧?做两个模板就可以解决了,不用那么复杂!
你看看这篇文章 http://www.23kaiyuan.com/516.html
请问楼主怎么解决的?

PHP在现代Web开发中仍然重要,尤其在内容管理和电子商务平台。1)PHP拥有丰富的生态系统和强大框架支持,如Laravel和Symfony。2)性能优化可通过OPcache和Nginx实现。3)PHP8.0引入JIT编译器,提升性能。4)云原生应用通过Docker和Kubernetes部署,提高灵活性和可扩展性。

PHP适合web开发,特别是在快速开发和处理动态内容方面表现出色,但不擅长数据科学和企业级应用。与Python相比,PHP在web开发中更具优势,但在数据科学领域不如Python;与Java相比,PHP在企业级应用中表现较差,但在web开发中更灵活;与JavaScript相比,PHP在后端开发中更简洁,但在前端开发中不如JavaScript。

PHP和Python各有优势,适合不同场景。1.PHP适用于web开发,提供内置web服务器和丰富函数库。2.Python适合数据科学和机器学习,语法简洁且有强大标准库。选择时应根据项目需求决定。

PHP是一种广泛应用于服务器端的脚本语言,特别适合web开发。1.PHP可以嵌入HTML,处理HTTP请求和响应,支持多种数据库。2.PHP用于生成动态网页内容,处理表单数据,访问数据库等,具有强大的社区支持和开源资源。3.PHP是解释型语言,执行过程包括词法分析、语法分析、编译和执行。4.PHP可以与MySQL结合用于用户注册系统等高级应用。5.调试PHP时,可使用error_reporting()和var_dump()等函数。6.优化PHP代码可通过缓存机制、优化数据库查询和使用内置函数。7

PHP成为许多网站首选技术栈的原因包括其易用性、强大社区支持和广泛应用。1)易于学习和使用,适合初学者。2)拥有庞大的开发者社区,资源丰富。3)广泛应用于WordPress、Drupal等平台。4)与Web服务器紧密集成,简化开发部署。

PHP在现代编程中仍然是一个强大且广泛使用的工具,尤其在web开发领域。1)PHP易用且与数据库集成无缝,是许多开发者的首选。2)它支持动态内容生成和面向对象编程,适合快速创建和维护网站。3)PHP的性能可以通过缓存和优化数据库查询来提升,其广泛的社区和丰富生态系统使其在当今技术栈中仍具重要地位。

在PHP中,弱引用是通过WeakReference类实现的,不会阻止垃圾回收器回收对象。弱引用适用于缓存系统和事件监听器等场景,需注意其不能保证对象存活,且垃圾回收可能延迟。

\_\_invoke方法允许对象像函数一样被调用。1.定义\_\_invoke方法使对象可被调用。2.使用$obj(...)语法时,PHP会执行\_\_invoke方法。3.适用于日志记录和计算器等场景,提高代码灵活性和可读性。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver CS6
视觉化网页开发工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

禅工作室 13.0.1
功能强大的PHP集成开发环境

WebStorm Mac版
好用的JavaScript开发工具