国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

輕松玩轉BootstrapTable(后端使用SpringMVC+Hibernate)

2019-11-19 15:32:25
字體:
來源:轉載
供稿:網友

還是那句老話,好記性不如爛筆頭。記得以前的一個Demo項目里面有分頁,但是沒有用插件,自己手寫的分頁處理,但是效果并不是很好,最近接觸到插件BootstrapTable,風格和Bootstrap統一,現在就來說說怎樣使用它。

初上手,直接套json數據進去,然后設置分頁方式為client',很快表格就做出來,但是一般項目中都是使用后臺來進行分頁的,不可能一下從數據庫從撈出成千上萬條數據,先不說流量的問題,客戶端的渲染也吃力。在使用服務器后端分頁的過程中,也遇到了一些問題,相信大部分初次接觸BootstrapTable的人應該都會遇到。所以特此寫一個完整的例子,后面應該還會繼續完善,包括增、刪、改。

好,廢話少說,上代碼。

先上項目架構:

項目使用maven構建,由于項目結構不是很復雜,所以就不做過多介紹。
接下來看index.jsp

<%@ page contentType="text/html;charset=UTF-8"%> <html>  <link rel="stylesheet" href="css/bootstrap.css" type="text/css" /> <link rel="stylesheet" href="css/bootstrap-table.css" type="text/css"> <script type="text/javascript" src="js/jquery-2.0.0.min.js"></script> <script type="text/javascript" src="js/bootstrap.js"></script> <script type="text/javascript" src="js/bootstrap-table.js"></script> <script type="text/javascript" src="js/bootstrap-table-zh-CN.js"></script>  <body>   <div class="panel panel-default">     <div class="panel-heading">       <h3 class="panel-title text-center">Bootstrap-table樣例演示</h3>     </div>     <div class="panel-body">        <div id="toolbar" class="btn-group">       <button id="btn_edit" type="button" class="btn btn-default">         <span class="glyphicon glyphicon-pencil" aria-hidden="true"></span>修改       </button>       <button id="btn_delete" type="button" class="btn btn-default">         <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>刪除       </button>     </div>      <table data-toggle="table" id="table" data-height="400"       data-classes="table table-hover" data-striped="true"       data-pagination="true" data-side-pagination="server"       data-search="true" data-show-refresh="true" data-show-toggle="true"       data-show-columns="true" data-toolbar="#toolbar">       <thead>         <tr>           <th data-field="state" data-checkbox='ture'></th>           <th></th>           <th></th>           <th></th>           <th></th>         </tr>       </thead>     </table>   </div>   </div>   </body>  <script type="text/javascript">   $("#superBtn").click(function() {     $.get("getPageInfo?limit=5&offset=0", function(data, status) {       alert(status);       alert(data.userList[0].name);     });   });      $(document).ready(function(){     $("button[name='toggle']").height(20);     $("button[name='refresh']").height(20);   });    function edit(id) {     alert(id);   }    $("#table")       .bootstrapTable(           {             url : "getPageInfo",  //數據請求路徑             clickToSelect : true, //點擊表格項即可選擇             dataType : "json",  //后端數據傳遞類型             pageSize : 5,             pageList : [ 5, 10, 20 ],           // contentType : "application/x-www-form-urlencoded",             method : 'get',   //請求類型             dataField : "data", //很重要,這是后端返回的實體數據!                      //是否顯示詳細視圖和列表視圖的切換按鈕             queryParams : function(params) {//自定義參數,這里的參數是傳給后臺的,我這是是分頁用的                return {//這里的params是table提供的                  offset : params.offset,//從數據庫第幾條記錄開始                  limit : params.limit               //找多少條                };             },             responseHandler : function(res) {               //在ajax獲取到數據,渲染表格之前,修改數據源               return res;             },             columns : [                 {                   field : 'state',                 },                 {                   field : 'id',                   title : 'ID',                   align : 'center'                 },                 {                   field : 'name',                   title : '姓名',                   align : 'center'                 },                 {                   field : 'age',                   title : '年齡',                   align : 'center'                 },                 {                   field : 'address',                   title : '地址',                   align : 'center'                 },                 {                   title : '操作',                   field : 'id',                   align : 'center',                   formatter : function(value, row, index) {                     var e = '<a href="#" mce_href="#" onclick="edit(/''                         + row.id + '/')">編輯</a> ';                     var d = '<a href="#" mce_href="#" onclick="del(/''                         + row.id + '/')">刪除</a> ';                     return e + d;                   }                  } ]           }); </script> </html> 

重要的幾點:

1、導入必要的css文件和js文件,并注意版本問題,這個后面會談 

2、queryParams:這是在點擊分頁或者初次加載表格的時候,前端向后端傳遞的數據,有2個,分別是limit和offset,limit表示請求的記錄條數,offset表示記錄的偏移量

3、dataField:表示后端傳遞的對象數據,名字要與對象的名字相同。

再來看Controller:

package controller;  import java.util.Map;  import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody;  import dao.UserDao;  @Controller public class BootstrapTableController {    @RequestMapping("/getPageInfo")   public @ResponseBody Map<String,Object> getPageInfo(int limit,int offset) {     System.out.println("limit is:"+limit);     System.out.println("offset is:"+offset);     UserDao userDao = new UserDao();     Map<String,Object> map = userDao.queryPageInfo(limit, offset);     return map;   } } 

Controller接收前端傳過來的limit和offset參數,然后根據這2個參數調用dao層方法來獲取數據。再看UserDao:

package dao;  import java.util.HashMap; import java.util.List; import java.util.Map;  import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.query.Query;  import entity.User;  public class UserDao {    private Session session;    private Transaction transaction;    public Session getSession() {     Configuration config = new Configuration().configure();     SessionFactory sessionFactory = config.buildSessionFactory();     Session session = sessionFactory.openSession();     return session;   }    public Map<String, Object> queryPageInfo(int limit, int offset) {     String sql = "from User";     Session session = this.getSession();      Query query = session.createQuery(sql);     query.setFirstResult(offset);     query.setMaxResults(limit);     List<User> userList = query.list();      String sql2 = "select count(*) from User";     int totalRecord = Integer.parseInt(session.createQuery(sql2).uniqueResult().toString());      Map<String, Object> map = new HashMap<String, Object>();     map.put("total", totalRecord);     map.put("data", userList);     return map;   } } 

userDao也是比較簡單的,關鍵就是total和data了,這是要返回到前臺的數據,注意名字要和前臺相對應,你只要返回實體數據和記錄總數就可以了,剩下的BootstrapTable替你搞定。
接下來在看看entity層的User

package entity;  public class User {    private int id;      private String name;      private int age;      private String address;    public User() {     super();   }    public User(int id,String name, int age, String address) {     super();     this.id = id;     this.name = name;     this.age = age;     this.address = address;   }    public String getName() {     return name;   }      public int getId() {     return id;   }    public void setId(int id) {     this.id = id;   }    public void setName(String name) {     this.name = name;   }    public int getAge() {     return age;   }    public void setAge(int age) {     this.age = age;   }    public String getAddress() {     return address;   }    public void setAddress(String address) {     this.address = address;   }    @Override   public String toString() {     return "User [id=" + id + ", name=" + name + ", age=" + age + ", address=" + address + "]";   } } 

還有幾個配置文件,分別是SpirngMVC的配置文件,還有web.xml以及pom.xml,該配的得配上:

SpringMVC-servlet.xml:

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"        xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xmlns:util="http://www.springframework.org/schema/util" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="  http://www.springframework.org/schema/beans  http://www.springframework.org/schema/beans/spring-beans-4.3.xsd  http://www.springframework.org/schema/util  http://www.springframework.org/schema/util/spring-util-4.3.xsd  http://www.springframework.org/schema/context   http://www.springframework.org/schema/context/spring-context-4.3.xsd  http://www.springframework.org/schema/mvc  http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd">  <!--   <mvc:annotation-driven/>  -->   <mvc:annotation-driven>     <mvc:message-converters>       <bean class="org.springframework.http.converter.StringHttpMessageConverter" />       <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter" />     </mvc:message-converters>   </mvc:annotation-driven>    <context:component-scan base-package="controller"/>     <!-- 這兩個類用來啟動基于Spring MVC的注解功能,將控制器與方法映射加入到容器中 -->   <bean     class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />   <bean     class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />    <!-- 這個類用于Spring MVC視圖解析 -->   <bean id="viewResolver"     class="org.springframework.web.servlet.view.InternalResourceViewResolver">     <property name="prefix" value="/WEB-INF/pages/" />     <property name="suffix" value=".jsp" />   </bean>   </beans> 

web.xml:

<!DOCTYPE web-app PUBLIC  "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"  "http://java.sun.com/dtd/web-app_2_3.dtd" >  <web-app>   <display-name>Archetype Created Web Application</display-name>    <servlet>     <servlet-name>SpringMVC</servlet-name>     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>     <load-on-startup>1</load-on-startup>   </servlet>   <servlet-mapping>     <servlet-name>SpringMVC</servlet-name>     <url-pattern>/</url-pattern>   </servlet-mapping>    <servlet-mapping>     <servlet-name>default</servlet-name>     <url-pattern>*.css</url-pattern>   </servlet-mapping>   <servlet-mapping>     <servlet-name>default</servlet-name>     <url-pattern>*.js</url-pattern>   </servlet-mapping>   <servlet-mapping>     <servlet-name>default</servlet-name>     <url-pattern>*.ttf</url-pattern>   </servlet-mapping>   <servlet-mapping>     <servlet-name>default</servlet-name>     <url-pattern>*.woff</url-pattern>   </servlet-mapping>   <servlet-mapping>     <servlet-name>default</servlet-name>     <url-pattern>*.woff2</url-pattern>   </servlet-mapping>  </web-app> 

pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">   <modelVersion>4.0.0</modelVersion>   <groupId>Demo</groupId>   <artifactId>BootstrapDemo</artifactId>   <packaging>war</packaging>   <version>0.0.1-SNAPSHOT</version>   <name>BootstrapDemo Maven Webapp</name>   <url>http://maven.apache.org</url>   <dependencies>     <dependency>       <groupId>junit</groupId>       <artifactId>junit</artifactId>       <version>3.8.1</version>       <scope>test</scope>     </dependency>     <dependency>       <groupId>javax.servlet</groupId>       <artifactId>javax.servlet-api</artifactId>       <version>3.1.0</version>       <scope>provided</scope>     </dependency>     <dependency>       <groupId>org.hibernate</groupId>       <artifactId>hibernate-core</artifactId>       <version>5.2.6.Final</version>     </dependency>      <dependency>       <groupId>mysql</groupId>       <artifactId>mysql-connector-java</artifactId>       <version>5.1.41</version>     </dependency>     <!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->     <dependency>       <groupId>org.springframework</groupId>       <artifactId>spring-webmvc</artifactId>       <version>4.3.10.RELEASE</version>     </dependency>     <dependency>       <groupId>com.fasterxml.jackson.core</groupId>       <artifactId>jackson-core</artifactId>       <version>2.8.9</version>     </dependency>     <dependency>       <groupId>com.fasterxml.jackson.core</groupId>       <artifactId>jackson-databind</artifactId>       <version>2.8.9</version>     </dependency>       <dependency>       <groupId>com.fasterxml.jackson.core</groupId>       <artifactId>jackson-annotations</artifactId>       <version>2.8.9</version>     </dependency>   </dependencies>   <build>     <finalName>BootstrapDemo</finalName>   </build> </project> 

然后dao層的就算了,很簡單。到這里基本上所有的關鍵都已經展示了,來看看效果吧:

不知道細心的你注意到沒有,右上角的一個按鈕明顯大了一圈,這不太好,其實是它左邊2個按鈕小了一圈,在網上找了很久,基本上沒有人遇到這樣的問題,沒辦法,逼我出絕招,使用調試器跟蹤這兩個按鈕元素,最后使用jQuery在表格加載完畢然后手動改變其大小,然后正常了。

當然,這只涉及到了查數據,還有數據的刪除、新增和修改,后面再來介紹這些的實現,其實最關鍵的還是查,查做出來了,其他的就水到渠成了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 祁连县| 岱山县| 榆中县| 佛学| 措美县| 澄迈县| 西安市| 琼海市| 香港| 高尔夫| 扎赉特旗| 永善县| 交口县| 林甸县| 济源市| 丹棱县| 安吉县| 鄱阳县| 鄂托克前旗| 彭水| 隆回县| 永丰县| 略阳县| 富顺县| 北辰区| 南漳县| 余江县| 额敏县| 荣成市| 清远市| 芦溪县| 大竹县| 临清市| 云和县| 奉新县| 富蕴县| 繁峙县| 遂溪县| 赤水市| 宁城县| 惠来县|