当前位置:首页 >> 网络编程

ajax结合豆瓣搜索结果进行分页完整代码

使用豆瓣api,得到分页结果。相当于从后台数据库获得的结果一样。所不同的是,没法事先知道页数。虽然通过请求api可以获得总页数,但由于ajax是异步的,所以对于分页一开始就要给出总页数来说,这是没有意义的。我使用了一个固定总页数65(正是搜索javascript书籍返回的总页数)。所以其他书籍是并不是65页,会出现多页或者少页的情况,这并不是bug。

特点

1、全程不需要接触后台,前端独立就可以(我找过好长时间都没找过完整的例子)。
2、使用了bootstrap的pagination制作页码和panel制作放置结果的面板。   

代码如下

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title></title>
 <link rel="stylesheet" href="css/bootstrap.css" /><!-- 换成自己的目录 -->
 <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=no" />
 </head>
 <style>
 .pagination> li > a {
 cursor: pointer;
 }
 .pagination > li > span {
 margin-left: 0;
 color: #ccc;
 background-color: transparent;
 cursor: default;
 }
 .pagination > li > span:hover {
 color: #ccc; 
 background-color: transparent;
 cursor: default; 
 }
 .m20 {
 margin: 20px 0;
 }

 </style>
 <body>

 <div class="container-fluid">

 <div class="col-md-12">
  <div class="panel panel-default">
  <div class="panel-heading">
  <form class="input-group">
  <input type="text" value="javascript" class="form-control" id="bookName" placeholder="请输入书名" required="required"/>
  <span class="input-group-btn">
   <button class="btn" id="search">搜索</button>
  </span>
  </form>
  </div>
  <div class="panel-body">
  <table class="table table-bordered">
  <thead>
   <th>书名</th>
   <th>作者</th>
   <th>出版日期</th>
   <th>平均分</th>
   <th>价格</th>
  </thead>
  <tbody id="tbody">

  </tbody>
  </table>
  </div>
  </div>

 <div class="row">
  <div class="col-md-6">
  <div id="test"></div>
  </div>

  <div class="col-md-4">
  <div class="input-group m20"><!-- 保持与#test中的.pagination对齐 -->
  <input type="text" class="form-control" id="page"/>
  <span class="input-group-btn">
  <button class="btn btn-default" id="jumpToPage">GO</button>
  </span>
  </div>
  </div>
 </div>

 <div id="result" class="alert alert-info"></div>
 </div>
 </div>


 <script type="text/javascript" src="/UploadFiles/2021-04-02/jquery-1.11.2.min.js">

参考

参考这里,书中的逻辑处理部分使用的是这里的代码,不过做了修改。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。