Boostrap-table后台传值,前台无响应——终结版(1)

不理解请回复,基本每天在线!!!!

阅读路线:
1.jsp页面:
2.js页面:(重点看,有可能会:迷闻经累劫,悟则刹那间)
3.Controller:
4.自己做的开发类向前台传递json数据工具类

jsp页面

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!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">
 <title>BootStrap Table使用</title>
    <!-- @*1、Jquery组件引用*@ -->
    <script src="js/jquery.min.js"></script>


    
    <!-- @*2、bootstrap组件引用*@ -->
    <script src="js/bootstrap.js"></script>
    <link href="css/bootstrap.css" rel="stylesheet" />
    
    <!-- @*3、bootstrap table组件以及中文包的引用*@ -->
    <script src="bootstrap-table/bootstrap-table.js"></script>
    <link href="bootstrap-table/bootstrap-table.css" rel="stylesheet" />
    <script src="bootstrap-table/locale/bootstrap-table-zh-CN.js"></script>
    
    <!-- @*4、页面Js文件的引用*@ -->
    <script src="js/bootstrap-table-fang.js"></script>
</head>
<body>
<div class="panel-body" style="padding-bottom: 0px;">
<div class="panel panel-default">
<div class="panel-heading">查询条件</div>
<div class="panel-body">
<form id="formSearch" class="form-horizontal" method="post">
<div class="form-group" style="margin-top: 15px">
<label class="control-label col-sm-1"
for="txt_search_departmentname">部门名称</label>
<div class="col-sm-3">
<input type="text" class="form-control"
id="txt_search_departmentname">
</div>
<label class="control-label col-sm-1" for="txt_search_statu">状态</label>
<div class="col-sm-3">
<input type="text" class="form-control" id="txt_search_statu">
</div>
<div class="col-sm-4" style="text-align: left;">
<button type="button" style="margin-left: 50px" id="btn_query"
class="btn btn-primary">查询</button>
</div>
</div>
</form>
</div>
</div>


<div id="toolbar" class="btn-group">
<button id="btn_add" type="button" class="btn btn-default">
<span class="glyphicon glyphicon-plus" aria-hidden="true"></span>新增
</button>
<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 id="tb_departments"></table>
</div>
</body>

</html>

js页面

var str;
$(function() {


// 1.初始化Table
var oTable = new TableInit();
oTable.Init();


// 2.初始化Button的点击事件
var oButtonInit = new ButtonInit();
oButtonInit.Init();


});


var TableInit = function() {
var oTableInit = new Object();
// 初始化Table
oTableInit.Init = function() {
$('#tb_departments').bootstrapTable({
url : '/BootstrapTest/UserServlet?flag=showtest', // 请求后台的URL(*)连接一般是项目名加controller
method : 'post', // 请求方式(*)
toolbar : '#toolbar', // 工具按钮用哪个容器
striped : true, // 是否显示行间隔色
cache : false, // 是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
pagination : true, // 是否显示分页(*)
sortable : false, // 是否启用排序
sortOrder : "asc", // 排序方式
queryParamsType:"undefined",
queryParams : oTableInit.queryParams,// 传递参数(*)
sidePagination : "server", // 分页方式:client客户端分页,server服务端分页(*)
pageNumber : 1, // 初始化加载第一页,默认第一页
pageSize : 10, // 每页的记录行数(*)
pageList : [ 10, 25, 50, 100 ], // 可供选择的每页的行数(*)
search : true, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大
strictSearch : true,
showColumns : true, // 是否显示所有的列
showRefresh : true, // 是否显示刷新按钮
minimumCountColumns : 2, // 最少允许的列数
clickToSelect : true, // 是否启用点击选中行
height : 500, // 行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度
uniqueId : "ID", // 每一行的唯一标识,一般为主键列
showToggle : true, // 是否显示详细视图和列表视图的切换按钮
cardView : false, // 是否显示详细视图
detailView : false, // 是否显示父子表
responseHandler:function (res) {
return{
//"total":res//总页数

"rows":res,//数据
}
            },
return{
//"total":res//总页数

"rows":res,//数据
}
            },
           
columns : [ {
checkbox : true
}, {
field : 'Name',
title : '部门名称'
}, {
field : 'ParentName',
title : '上级部门'
}, {
field : 'Level',
title : '部门级别'
}, {
field : 'Desc',
title : '描述'
},
{
field:'goodsId',
title:'操作',
formatter:function(value,row,index){
var ret='<button class="btn btn-info" οnclick="handler.goodsBuy('+value+');">购买</button>';
return ret;
}
}]


});
};
   
// 得到查询的参数
oTableInit.queryParams = function(params) {
var temp = { // 这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的
limit : params.limit, // 页面大小
offset : params.offset, // 页码
departmentname : $("#txt_search_departmentname").val(),
statu : $("#txt_search_statu").val()
};
return temp;
};
return oTableInit;
};


var ButtonInit = function() {
var oInit = new Object();
var postdata = {};


oInit.Init = function() {
// 初始化页面上面的按钮事件
};


return oInit;

};

Controller页面

package com.fang.controller;


import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;


import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


import com.fang.dao.UserDAO;
import com.fang.daoImp.UserDAOImp;
import com.fang.entity.UserEntity;
import com.fang.util.AjaxRequestUntils;


/**
 * Servlet implementation class UserServlet
 */
@WebServlet("/UserServlet")
public class UserServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
private UserDAO dao=new UserDAOImp();


    /**
     * Default constructor. 
     */
    public UserServlet() {
        // TODO Auto-generated constructor stub
    }


/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
response.getWriter().append("Served at: ").append(request.getContextPath());
}


/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.先置统一字符串
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
String name=request.getParameter("username");
String pass=request.getParameter("password");
String flag=request.getParameter("flag");

if("login".equals(flag)){

  int a=dao.login(name,pass);
   if(a>0){
//把用户名通过session传递出去
request.getSession().setAttribute("username", name);
request.getRequestDispatcher("bootstrap-table-fang.jsp").forward(request, response);
   }else{
response.sendRedirect("Login.jsp");
    }
     }
if("off".equals(flag)){
request.getSession().removeAttribute("username");
request.getRequestDispatcher("Login.jsp").forward(request, response);
}if("showtest".equals(flag)){//展示数据
System.out.println("来到这里了吗?");
showRsb(request,response);
}

}
/**
* 新添加的方法
* @param limit
* @param offset
* @param departmentname
* @param statu
* @return
*/
public void showRsb(HttpServletRequest request,HttpServletResponse response)
    {
       List<Map<String, Object>> list=dao.showRsb();
      
       AjaxRequestUntils.AjaxAndJsonArray(list, request, response);
    }



}


贡献一个自己开发的untils工具类

package com.fang.util;


import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;


import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;


import com.alibaba.fastjson.JSONArray;






/**
 * ajax异步请求
 * @author fang
 *
 */
public class AjaxRequestUntils {


/**
* ajax与json相互调用

* @param jsonArray
* @param request
* @param response
*/
public static void AjaxAndJsonArray(List list, HttpServletRequest request, HttpServletResponse response) {
JSONArray jsonArray = new JSONArray(list);// 转换成JSon传给jsp
try {


response.setHeader("Access-Control-Allow-Origin", "*");
response.setContentType("text/json;charset=utf-8");
PrintWriter out = response.getWriter();

out.print(jsonArray);
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* AjaxAndJsonObject

* @param object
* @param request
* @param response
*/
public static void AjaxAndJsonObject(Object object, HttpServletRequest request, HttpServletResponse response) {
try {
response.setHeader("Access-Control-Allow-Origin", "*");
// 这是一种输出流,
response.setContentType("text/json;charset=utf-8");
PrintWriter out = response.getWriter();
out.println(object);
} catch (IOException e) {
e.printStackTrace();
}
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值