layui表格数据能否用ajax获取,layui表格通过servlet连接数据库拿到数据

1.layui布局表格

搜索ID:

搜索

layui.use('table',function(){

var table =layui.table;

//方法级渲染

table.render({

elem:'#LAY_table_user'

,url:'http://localhost:8080/onlineTest_war_exploded/question'

,cols: [[

,{field:'questionId',title:'题号',width:200}

,{field:'questionTitle',title:'题目',width:300}

,{field:'city',title:'通过率',width:200}

,{field:'classify',title:'难度',width:200}

]]

,id:'testReload'

,page:true

,height:310

});

var $ =layui.$,active = {

reload:function(){

var demoReload =$('#demoReload');

//执行重载

table.reload('testReload', {

page: {

curr:1 //重新从第 1 页开始

}

,where: {

key: {

id:demoReload.val()

}

}

},'data');

}

};

$('.demoTable .layui-btn').on('click',function(){

var type =$(this).data('type');

active[type] ?active[type].call(this) :'';

});

});

e939931a295e

url是servlet在web.xml下手动配置的路径

e939931a295e

第一个javabean对象是存放表格原始数据 第二个javabean是存放code msg count和表格原始数据的 把第二个javabean转换为json格式发给后台

e939931a295e

如图 第一次检查的时候发现传回去的json里面带\ 原因:之前用ajax已经把存放列表原始数据的数据转换为json了 再用第二个javabean对象又转换了一次相当于没转换 所以识别不出来

结果:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这里提供一个简单的示例,实现基于 Spring MVC 和 Ajax表格查询功能,使用的前端框架是 layui 数据表格数据库使用的是 MySQL。 1. 在 pom.xml 文件中添加以下依赖: ```xml <!-- Spring MVC --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <!-- Jackson JSON --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>${jackson.version}</version> </dependency> <!-- MySQL JDBC --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>${mysql.version}</version> </dependency> ``` 2. 在 Spring 配置文件中添加以下配置: ```xml <!-- 数据源配置 --> <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/test" /> <property name="username" value="root" /> <property name="password" value="password" /> </bean> <!-- MyBatis 配置 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="typeAliasesPackage" value="com.example.model" /> <property name="mapperLocations" value="classpath*:com/example/mapper/*.xml" /> <property name="configLocation" value="classpath:mybatis-config.xml" /> </bean> <!-- MyBatis Mapper 扫描 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.example.mapper" /> </bean> <!-- 开启 Spring MVC 注解支持 --> <annotation-driven/> <!-- 静态资源处理 --> <mvc:resources mapping="/static/**" location="/static/" /> <!-- 视图解析器 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> ``` 3. 在 Spring MVC 配置文件中添加以下配置: ```xml <!-- 开启注解驱动 --> <mvc:annotation-driven /> <!-- 配置处理器映射器 --> <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping" /> <!-- 配置控制器 --> <bean name="/ajaxTable" class="com.example.controller.AjaxTableController" /> <!-- 配置 AJAX 返回值处理器 --> <bean class="org.springframework.web.servlet.view.json.MappingJackson2JsonView" /> ``` 4. 创建一个实体类 User,对应 MySQL 数据库中的 user 表: ```java public class User { private Long id; private String username; private String email; private String phone; // getter 和 setter 方法省略 } ``` 5. 创建一个 DAO 接口 UserMapper,使用 MyBatis 进行数据库操作: ```java public interface UserMapper { List<User> selectByCondition(Map<String, Object> condition); } ``` 6. 创建一个控制器 AjaxTableController,实现搜索功能: ```java @Controller public class AjaxTableController { @Autowired private UserMapper userMapper; @RequestMapping("/ajaxTable") public ModelAndView ajaxTable() { return new ModelAndView("ajaxTable"); } @RequestMapping("/ajaxTable/search") @ResponseBody public Map<String, Object> search(HttpServletRequest request) { Map<String, Object> result = new HashMap<>(); String username = request.getParameter("username"); String email = request.getParameter("email"); String phone = request.getParameter("phone"); Map<String, Object> condition = new HashMap<>(); condition.put("username", username); condition.put("email", email); condition.put("phone", phone); List<User> userList = userMapper.selectByCondition(condition); result.put("code", 0); result.put("msg", ""); result.put("count", userList.size()); result.put("data", userList); return result; } } ``` 7. 创建一个 JSP 页面 ajaxTable.jsp,使用 layui 数据表格展示数据: ```html <!doctype html> <html> <head> <meta charset="UTF-8"> <title>Ajax Table</title> <link rel="stylesheet" href="/static/layui/css/layui.css"> </head> <body> <div class="layui-container"> <div class="layui-row layui-col-space15"> <div class="layui-card"> <div class="layui-card-body"> <form class="layui-form layui-form-pane" lay-filter="table-search"> <div class="layui-form-item layui-inline"> <label class="layui-form-label">Username</label> <div class="layui-input-inline"> <input type="text" name="username" class="layui-input" autocomplete="off"> </div> </div> <div class="layui-form-item layui-inline"> <label class="layui-form-label">Email</label> <div class="layui-input-inline"> <input type="text" name="email" class="layui-input" autocomplete="off"> </div> </div> <div class="layui-form-item layui-inline"> <label class="layui-form-label">Phone</label> <div class="layui-input-inline"> <input type="text" name="phone" class="layui-input" autocomplete="off"> </div> </div> <div class="layui-form-item"> <div class="layui-input-inline"> <button class="layui-btn" type="button" lay-submit lay-filter="table-search-btn">Search</button> <button class="layui-btn layui-btn-primary" type="reset">Reset</button> </div> </div> </form> </div> </div> <div class="layui-card"> <div class="layui-card-body"> <table id="userTable" lay-filter="userTable"></table> </div> </div> </div> </div> <script src="/static/layui/layui.js"></script> <script> layui.use(['table', 'form'], function () { var table = layui.table; var form = layui.form; table.render({ elem: '#userTable', url: '/ajaxTable/search', method: 'post', page: true, cols: [[ {field: 'id', title: 'ID', width: 80}, {field: 'username', title: 'Username', width: 120}, {field: 'email', title: 'Email', width: 200}, {field: 'phone', title: 'Phone', width: 120} ]] }); form.on('submit(table-search-btn)', function (data) { table.reload('userTable', { where: data.field }); return false; }); }); </script> </body> </html> ``` 通过访问 `/ajaxTable` 页面即可看到一个带搜索功能的数据表格。用户输入搜索条件后,点击搜索按钮即可实现异步请求,后台根据条件查询数据库,将查询结果返回给前端,前端使用 layui 数据表格展示数据

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值