Spring + Struts + Hibernate + Bootstrap-table 实现分页和增删改查
1、bootstrap界面效果图:

2、Teacher实体类
public class Teacher {
private int id;
private String name;
private String phone;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
}
3、TeacherDao
public interface TeacherDao extends BaseDao<Teacher>{
}
4、TeacherDaoImpl
public class TeacherDaoImpl extends BaseDaoImpl<Teacher> implements TeacherDao{
}
5、TeacherService
public interface TeacherService extends BaseService<Teacher>{
}
6、TeacherServiceImpl
public class TeacherServiceImpl extends BaseServiceImpl<Teacher> implements TeacherService{
}
7、TeacherAction
public class TeacherAction extends BaseAction<Teacher>{
private String name;
private String phone;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public void grid() {
super.filter = "1=1";
if (!"".equals(name) && name != null) {
super.filter += " AND name like '%" + name + "%'";
}
if (!"".equals(phone) && phone != null) {
super.filter += " AND phone like '%" + phone + "%'";
}
super.grid();
}
public void save(){
super.id=entity.getId();
super.save();
}
public void getById(){
super.getById();
}
public void delete(){
super.delete();
}
}
8、bootstrap布局
<div class="container">
<h3>教师管理</h3>
<hr>
<!-- 查询块 -->
<div class="row collapse" id="collapseFilter" aria-expanded="true">
<div class="col-md-12">
<h5>查询条件</h5>
<div class="box-body">
<form class="form-inline" >
<div class="form-group">
<input id="name" type="text" class="form-control" placeholder="名字" />
</div>
<div class="form-group">
<input id="phone" type="text" class="form-control" placeholder="电话" />
</div>
<button id="btn_search" type="button" class="btn btn-primary btn-sm" onclick="search();"> <span class="glyphicon glyphicon-search" aria-hidden="true"></span>查询 </button>
<button id="btn_clean_search" type="button" class="btn btn-danger btn-sm" onclick="clearSearch();">清空条件</button>
</form>
</div>
</div>
</div>
<!-- 表格块 -->
<div class="row">
<div class="col-md-12">
<div id="toolbar">
<!-- 工具栏 -->
<button type="button" class="btn btn-primary btn-sm" onclick="addData();"><span class="fa fa-plus" aria-hidden="true"></span> 新增 </button>
<button type="button" class="btn btn-primary btn-sm" onclick="editData();"><span class="fa fa-pencil" aria-hidden="true"></span> 修改 </button>
<button type="button" class="btn btn-primary btn-sm" onclick="deleteData();"><span class="fa fa-trash" aria-hidden="true"></span> 删除 </button>
<button type="button" class="btn btn-primary btn-sm" data-toggle="collapse" data-target="#collapseFilter" aria-expanded="true" aria-controls="collapseFilter"> <i class="fa fa-filter"></i> 查询 </button>
</div>
<!-- 表格 -->
<table id="mytable" class="table table-hover"></table>
</div>
</div>
</div> <!-- 模态框(Modal) -->
<div class="modal fade" id="formModal" tabindex="-1" role="dialog" aria-labelledby="modalLabel" aria-hidden="true">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 id="modalTitle" class="modal-title"></h4>
</div>
<div class="modal-body">
<form class="form-horizontal" id="myform" enctype="multipart/form-data">
<input type="hidden" name="entity.id" id="txt_id"/>
<div class="box-body">
<div class="form-group">
<label class="col-sm-2 control-label">教师名称</label>
<div class="col-sm-9">
<input type="text" class="form-control" name="entity.name" id="txt_name" required="" placeholder="教师名称" autocomplete="off">
</div>
</div>
<div class="form-group">
<label class="col-sm-2 control-label">电话号码</label>
<div class="col-sm-9">
<input type="text" class="form-control" name="entity.phone" id="txt_phone" required="" placeholder="电话号码" autocomplete="off">
</div>
</div>
</div>
<!-- /.box-body -->
<div class="box-footer text-right">
<button type="button" class="btn btn-default" data-btn-type="cancel" data-dismiss="modal"><span class="fa fa-remove" aria-hidden="true"></span> 关闭 </button>
<button type="button" id="btnOK" onclick="submitData();" class="btn btn-primary"><span class="fa fa-save" aria-hidden="true"></span> 提交 </button>
</div>
<!-- /.box-footer -->
</form>
</div>
</div>
</div>
</div>
<!-- 模态框(Modal) -->
9、teacher_table.js
var $table = $('#mytable');
$(function(){
initTable(null);
});
//表格初始化
function initTable(searchArgs) {
$table.bootstrapTable('destroy');
$table.bootstrapTable({
url: 'http://localhost:8080/ssh/teacherGrid',
method: 'post',
contentType: "application/x-www-form-urlencoded",
dataType: "json",
striped: true,//是否显示行间隔色
sortable: true, //是否启用排序
sortName: "id",//排序字段
sortOrder: "desc", //排序方式
cache: false,//是否使用缓存
uniqueId: "id",//每行的唯一标识
toolbar: "#toolbar",//指定工具栏
showColumns: true,//显示隐藏列列选择按钮
search: false, //是否显示搜索框
showRefresh: false, //显示刷新按钮
showToggle: false,//切换显示样式
showFooter: false, //显示Table脚部
pagination: true,//是否显示分页
showPaginationSwitch: false, //是否显示分页按钮
clickToSelect: false, //是否启用点击选中行
minimumCountColumns: 2, //最少要显示的列数
undefinedText: '-', //cell没有值时显示
sidePagination: "server", //分页方式:client客户端分页,server服务端分页
pageSize: 3,//每页的记录行数
pageNumber: 1, //初始化加载第1页,默认第1页
pageList: "[5,10,20]",//可供选择的每页的行数
height:tableHeight(),
iconsPrefix: 'glyphicon',
/* queryParamsType的默认值为 'limit' ,在默认情况下 传给服务端的参数为:offset,limit,sort
设置为 '' 在这种情况下传给服务器的参数为:pageSize,pageNumber */
queryParamsType:'',
queryParams: function queryParams(params) {
var param = {
pageNumber: params.pageNumber,
pageSize: params.pageSize,
sortName:this.sortName,
sortOrder:this.sortOrder
};
if(searchArgs!=null){
for(var key in searchArgs){
param[key]=searchArgs[key];
}
}
return param;
},
editable:false,//开启编辑模式
columns: [{
field: 'state',
checkbox: true,
align: 'center',
valign: 'middle'
},
{
title: '教师名称',
field: 'name',
align: 'center',
valign: 'middle',
sortable: true
}, {
title: '手机号码',
field: 'phone',
align: 'center',
valign: 'middle',
sortable: true
}],
onLoadSuccess: function () {
//加载成功时执行
console.log("加载成功!");
}, onLoadError: function () {
//加载失败时执行
console.log("加载失败!");
}, formatLoadingMessage: function () {
//正在加载
return "请稍等,正在加载中...";
}, formatNoMatches: function () {
//没有匹配的结果
return '无符合条件的记录';
}
});
}
//获取窗口高度
function tableHeight() {
return $(window).height() - 160;
}
//搜索分页查询
function search(){
var searchArgs={
name : $("#name").val(),
phone: $("#phone").val()
};
initTable(searchArgs);
}
//清空条件按钮点击事件
function clearSearch(){
$('#name').val("");
$('#phone').val("");
initTable(null);
}
10、teacher_crud.js
//获取选中的id
function getIdSelections() {
return $.map($table.bootstrapTable('getSelections'), function (row) {
return row.id
});
}//打开模态框
function addData(){
$("#modalTitle").text("添加教师");
$('#formModal').modal('show');
} //关闭模态框时重置表单
$('#formModal').on('hide.bs.modal', function() {
$("#txt_id").val("");
$("#txt_name").val("");
$("#txt_phone").val("");
}); //保存数据
function submitData(){
var param = $("#myform").serialize();
console.log(param);
$.ajax({
type: "post",
url: "http://localhost:8080/ssh/saveTeacher",
data: param ,
dataType: 'json',
contentType: "application/x-www-form-urlencoded; charset=utf-8",
success: function(data) {
console.log("保存返回的数据:"+JSON.stringify(data));
$('#formModal').modal('hide');
if(data['msg']){
toastr.success(data['msg']);
}else{
toastr.error(data['msg']);
}
initTable(null);
} });
} //编辑数据
function editData(){
var ids = getIdSelections();
if (ids.length != 1) {
toastr.info('选择一条数据进行编辑!');
} else {
var id= parseInt(ids);
console.log("编辑的id:"+id);
$.ajax({
type: "post",
url: "http://localhost:8080/ssh/getTeacher",
data: {id:id},
dataType: 'json',
contentType: "application/x-www-form-urlencoded; charset=utf-8",
success: function(data) {
console.log("获取单条数据:"+JSON.stringify(data));
$('#txt_id').val(data.id);
$('#txt_name').val(data.name);
$('#txt_phone').val(data.phone);
$("#modalTitle").text("编辑教师");
$('#formModal').modal('show');
} });
}
} //删除数据
function deleteData(){
var ids = getIdSelections().toString();
if (ids.length > 0) {
console.log("删除的ids:"+ids);
if(confirm("确定要删除选中的数据吗?")){
$.ajax({
type: "post",
url: "http://localhost:8080/ssh/deleteTeacher",
data: {"ids":ids},
dataType: 'json',
contentType: "application/x-www-form-urlencoded; charset=utf-8",
success: function(data) {
console.log("删除返回的数据:"+JSON.stringify(data));
if(data['msg']){
toastr.success(data['msg']);
}else{
toastr.error(data['msg']);
}
initTable(null);
} });
} } else {
toastr.warning('选择要删除的数据!');
} }
这是小编的原创随笔,请尊重原创,若是转载请注明出处,谢谢。
Spring + Struts + Hibernate + Bootstrap-table 实现分页和增删改查的更多相关文章
- ssm框架(Spring Springmvc Mybatis框架)整合及案例增删改查
三大框架介绍 ssm框架是由Spring springmvc和Mybatis共同组成的框架.Spring和Springmvc都是spring公司开发的,因此他们之间不需要整合.也可以说是无缝整合.my ...
- 初识Hibernate框架,进行简单的增删改查操作
Hibernate的优势 优秀的Java 持久化层解决方案 (DAO) 主流的对象—关系映射工具产品 简化了JDBC 繁琐的编码 将数据库的连接信息都存放在配置文件 自己的ORM框架 一定要手动实现 ...
- 16~25.spring+hibernate简单实例 .连接数据库并进行增删改查
1.概念 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQ ...
- Spring boot+mybatis+thymeleaf 实现登录注册,增删改查
本文重在实现理解,过滤器,业务,逻辑需求,样式请无视.. 项目结构如下 1.idea新建Spring boot项目,在pom中加上thymeleaf和mybatis支持.pom.xml代码如下 < ...
- WPF DataGrid 数据绑定、样式、分页、增删改查,连接Access数据库
先上效果图: XAML: <UserControl xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation&q ...
- Spring学习笔记:声明式事务管理增删改查业务
一.关于是事务 以方法为单位,进行事务控制:抛出异常,事务回滚. 最小的执行单位为方法.决定执行成败是通过是否抛出异常来判断的,抛出异常即执行失败 二.声明式事务: 声明式事务(declarative ...
- Hibernate级联及控制反转的增删改查
在JavaHibernate中,双向多对一的操作一直是一个重点难点,本篇文章就是来探讨这个问题. 双向多对一:一个班级对应多个学生,多个学生同属于一个班级,通过班级信息可以查到班级内的学生,通过学生可 ...
- 14.hibernate的反向生成实现全套增删改查
图片顺序就是步骤顺序 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18.
- SSH(Struts 2.3.31 + Spring 4.1.6 + Hibernate 5.0.12 + Ajax)框架整合实现简单的增删改查(包含分页,Ajax 无刷新验证该用户是否存在)
软件152 余建强 该文将以员工.部门两表带领大家进入SSH的整合教程: 源码下载:http://download.csdn.net/detail/qq_35318576/9877235 SSH 整合 ...
随机推荐
- tcp的重传与超时
TCP协议是一种面向连接的可靠的传输层协议,它保证了数据的可靠传输,对于一些出错,超时丢包等问题TCP设计的超时与重传机制. 其基本原理:在发送一个数据之后,就开启一个定时器,若是在这个时间内没有收到 ...
- JavaScript HTMlL DOM对象(下)
DOM:document operation model 文档操作模型 每个标签都是一个对象. 一.查找元素 DOM 回顾 直接查找 var obj = document.getElementById ...
- [转] Exchange 2013 安装部署详解
·Exchange 2013 部署:系统要求 823 / 3 部署 系统要求 Exchange 2013 zhou_ping 2013-02-17 ·Exchange 2013 部署:先决条件 752 ...
- Javascript基础之-var,let和const深入解析(二)
你想在在变量声明之前就使用变量?以后再也别这样做了. 新的声明方式(let,const)较之之前的声明方式(var),还有一个区别,就是新的方式不允许在变量声明之前就使用该变量,但是var是可以得.请 ...
- Red 编程语言 2019 开发计划:全速前进!
开发四年只会写业务代码,分布式高并发都不会还做程序员? >>> Red 编程语言开发团队昨日发布了一篇 "Full steam ahead" 的文章,对其 2 ...
- 如何在linux服务器下快速安装配置Node.js
简单粗暴,先用xshell或其他软件连接服务器 1.下载(此处版本根据官网版本自己修改) wget https://npm.taobao.org/mirrors/node/v8.9.3/node-v8 ...
- python练习---博客登录(装饰器)
程序要求: 1),启动程序,首页面应该显示成如下格式: 欢迎来到博客园首页 1:请登录 2:请注册 3:文章页面 4:日记页面 5:评论页面 6:收藏页面 7:注销 8:退出程序2),用户输入选项,3 ...
- 《C程序设计语言》 练习1-21
问题描述 编写程序entab,将空格串替换为最少数量的制表符和空格,但要保持单词之间的间隔不变.假设制表符终止位的位置与练习1 - 20的detab程序的情况相同.当使用一个制表符或者一个空格都可以到 ...
- Jenkins 邮件收发(qq 邮箱)
一.配置 Jenkins 邮箱的全局配置 检查是否已安装插件 Email Extension Plugin 获取 qq 邮箱 授权码 进入 qq 邮箱 ---> 设置 ---> 账户 配置 ...
- Docker 结合Jenkins 构建持续集成环境
Docker 结合Jenkins 构建持续集成环境 Jenkins : 一个开源的持续集成工具, 提供软件版本发布.自动测试等一系列流程及丰富的插件 Maven: 一个自动化构建工具, 通过一段描述 ...