angular js 实现模糊查询并分页
如果这篇文章能给你带来帮助,不胜荣幸,如果有不对的地方也请批评指正 共同进步,因为最近使用augular前段所以看了一下,为了加深印象,所以记录一下,废话不多说直接上代码。
首先来讲你可以使用page的分页插件,也可以不使用我没有使用,所以得展示部分sql语句。总体来说sql语句的代码就是:select * from table where 1=1 and 条件=条件值 and 条件=条件值 limit start,num 并写一个查询相关条数的方法
其中start为起始下标,num为展示多少条。具体看下面
<select id="selectByPageAndObj" resultMap="BaseResultMap"> select * from registration_of_cases <where> <if test="unitName!=null"> and unit_name like concat("%",#{unitName},"%") </if> <if test="organizationalCode!=null"> and organizational_code like concat("%",#{organizationalCode},"%") </if> </where> limit #{nowPage},#{pagetotle} </select>
<select id="selectByPageAndObjNum" resultType="int"> select count(*) from registration_of_cases <where> <if test="unitName!=null"> and unit_name like concat("%",#{unitName},"%") </if> <if test="organizationalCode!=null"> and organizational_code like concat("%",#{organizationalCode},"%") </if> </where> </select>
然后需要创建一个分页类:分页累的作用就是简单地给你进行一下计算,比如说传入当前的页数 可以得到查询的起始位置等等不在一一赘述,看代码
package com.social.util;
import java.util.List;
public class Result {
private int pageSize = 5;//每页数量
private int pageNum = 1;//默认当前是第一页
private int total = 0;//总条数
private int totalPage = 0;//总页数
private int start = 0;//起始位置
private List rows;//接受数据的集合
private String url="";//请求的路径
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getPageNum() {
return pageNum;
}
public void setPageNum(int pageNum) {
this.pageNum = pageNum;
}
public int getTotal() {
return total;
}
public void setTotal(int total) {
this.total = total;
}
public int getTotalPage() {
int pageCount = 0;
if(total%pageSize==0) {
pageCount=total/pageSize;
}else {
pageCount=total/pageSize+1;
}
totalPage = pageCount;
return totalPage;
}
public void setTotalPage(int totalPage) {
this.totalPage = totalPage;
}
public int getStart() {
start = (pageNum-1)*pageSize;
return start;
}
public void setStart(int start) {
this.start = start;
}
public List getRows() {
return rows;
}
public void setRows(List rows) {
this.rows = rows;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
@Override
public String toString() {
return "PageBean [pageSize=" + pageSize + ", pageNum=" + pageNum + ", total=" + total + ", totalPage="
+ totalPage + ", start=" + start + ", rows=" + rows + ", url=" + url + "]";
}
}
在写这个之前,还得写一个查询所有的方法,如果你nb其实一个方法也可以,这篇文章就是给基础的看的。接着往下
后台的工作目前做到这里就算差不多的了 现在来看一下前台界面你需要写一部分js 上代码:
首先引入相关的js和css样式 例如:
<script src="plugins/jQuery/jquery-2.2.3.min.js"></script>
<script src="plugins/bootstrap/js/bootstrap.min.js"></script>
<link rel="stylesheet" href="plugins/bootstrap/css/bootstrap.min.css">
<link rel="stylesheet" href="plugins/angularjs/pagination.css">
<script type="text/javascript" src="plugins/angularjs/pagination.js"></script>
<script type="text/javascript" src="plugins/angularjs/angular.min.js"></script>
然后接着上具体的前段代码 部分解释代码中见:
//初始化和点击时给部分分页的参数进行一个赋值 前段的分页
$scope.paginationConf = {
currentPage : 1,//当前页
totalItems : 0,//总数
itemsPerPage : 5,//每页个数
perPageOptions : [ 5, 10, 15, 20, 50 ],//分页选项
onChange : function() {//当更改页码时,自动触发分页查询方法
$scope.reloadlist();
}
};
$scope.searchEntity = {
unitName : "",//
organizationalCode : "",//
};
//有改变的时候调用重新加载的方法
$scope.reloadlist = function() {//方法里面有两个参数 当前页和每页多少条
$scope.findPage($scope.searchEntity.unitName,$scope.searchEntity.organizationalCode,$scope.paginationConf.currentPage,
$scope.paginationConf.itemsPerPage);
}
//根据条件进行分页查询
$scope.findPage = function(unitName,organizationalCode,nowPage, pageTotal) {
$http({
method:'post',
url:'http://localhost:80/mysocial/pageFindByObj',
data:{
"unitName":unitName,
"organizationalCode":organizationalCode,
"nowPage":nowPage,
"pageTotal":pageTotal
},
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
transformRequest: function(obj) {
var str = [];
for (var s in obj) {
str.push(encodeURIComponent(s) + "=" + encodeURIComponent(obj[s]));
}
return str.join("&");
}
}).success(function(response){
$scope.list = response.rows;//显示当前页数据
$scope.paginationConf.totalItems = response.total;//更新总记录数
})
}
具体的html界面上的代码:
<tr ng-repeat="entity in list"> <!-- 你可以吧repeat当成foreach来理解 其中 list是上面接收的集合 entity是用来循环展示的变量 -->
<td><input type="checkbox"></td>
<td>{{entity.unitName}}</td> <!-- 通过对象.属性的方式来进行一个展示数据 -->
<td>{{entity.organizationalCode}}</td>
<td>{{entity.nameOfTheComplainant}}</td>
</tr>
<!-- 最后在你的前台html界面上进行一个插件html的引入-->
<tm-pagination conf="paginationConf"></tm-pagination>
最后展示后台代码:查询所有的的代码我就不展示了,反正也是得返回一个pagebean 要不然你前台获取的时候获取不到相对应的值
·
@Autowired
private RegistrationOfCasesMapper registrationOfCasesMapper;
@ResponseBody
@RequestMapping("/pageFindByObj")
public Result pageFindByObj(String unitName,String organizationalCode,Integer nowPage,Integer pageTotal){
//创建result对象
Result result = new Result();
result.setPageNum(nowPage);
result.setPageSize(pageTotal);
List<RegistrationOfCases> selectByPageAndObj = registrationOfCasesMapper.selectByPageAndObj(unitName,organizationalCode,result.getStart(),pageTotal);
Integer selectByPageAndObjNum = registrationOfCasesMapper.selectByPageAndObjNum(unitName,organizationalCode, result.getStart(), pageTotal);
result.setRows(selectByPageAndObj);
result.setTotal(selectByPageAndObjNum);
return result;
}
angular js 实现模糊查询并分页的更多相关文章
- django实战(二)--带多字段模糊查询的分页(也是不容易)
上节我们实现了分页功能,这节我们要实现对模糊查询后的结果进行分页.(引入了bootstrap框架) urls.py from django.urls import path from . import ...
- 【Django+Element UI】使用一个接口文件,搞定分页获取数据,模糊查询后分页获取数据
1:序列化获取数据的接口设计 1:分页获取序列化数据 2:是个能传参数的接口 class Society(APIView): def post(self, request): keywords = s ...
- 利用DetachedCriteria实现模糊查询和分页
分类: Java-Developing 前段时间在做模糊查询,并利用数据库分页,DAO用hibernate实现,刚开始的时候 根据业务层的数据,拼hql语句进行查询,且不说要进行一些if判断,单 ...
- 编写简易的JS输入框模糊查询匹配(附有源码和demo)
前言:JS输入框模糊匹配插件以前在工作写过一个类似的 所以这次写轻松很多,这次写优化了几个方面: 1. 添加动态加载css文件 不需要引入css css全部在JS动态生成. 2. 不需要额外的标签 只 ...
- js实现模糊查询
1.简述 实现模糊查询方法有很多种,后端可以实现,前端使用js也可以实现. 后端实现起来需要根据输入框中搜索的关键字,去后台拼接SQL语句查询. 前端直接使用字符串的indexOf()方法或者正则表达 ...
- Spring Boot 结合Spring Data结合小项目(增,删,查,模糊查询,分页,排序)
本次做的小项目是类似于,公司发布招聘信息,因此有俩个表,一个公司表,一个招聘信息表,俩个表是一对多的关系 项目整体结构: Spring Boot和Spring Data结合的资源文件 applicat ...
- Neo4j模糊查询及分页查询
Neo4j模糊查询:采用正则方式: MATCH (n:House) where n.Name =~ '李.*' RETURN n 分页: 使用skip 及 limit MATCH (n:House) ...
- Mysql里查询字段为Json格式的数据模糊查询以及分页方法
public void datagrid(CustomFormEntity customForm,HttpServletRequest request, HttpServletResponse res ...
- Thinkphp5 post提交模糊查询带分页如何保留参数
最近做了一个分页的模糊查询post请求,发现查出来的分页点击下一页导致所有的搜索条件被重置,分页效果就失效了. 以下是网上部分解决办法: 控制器代码 public function index($na ...
- js的模糊查询
在项目中会用到模糊查询,之前在首页是用的element的tree显示的目录,会有用到搜索,但tree里边会有自带的模糊查询,用filter-node-method方法使用 但上次的项目中 又涉及到不试 ...
随机推荐
- python之路32 网络并发线程方法 线程池 协程
多进程实现TCP服务端并发 服务端: import socket from multiprocessing import Process def get_server(): server = sock ...
- Java基础篇——Gui编程
AWT 抽象窗口工具 组件:按钮(button) 文本域(textarea) 标签(label) 容器(container)... Frame窗口 Frame frame = new Frame( ...
- Java运算的精度和溢出问题
double和float的0.1问题 代码如下 public class demo2 { public static void main(String[] args) { float f=0.1f; ...
- Sublime下运行javascript,并带彩色提示
最近和各种同事磨合技术,自闭中~ 首先让JS在Sublime上运行 去下载Node.js并且安装 安装完成后 cmd 输入 node -v 查看安装是否成功. 接着打开Sublime - 工具 > ...
- [Vue warn]: Invalid prop: type check failed for prop "model". Expected Object, got String with value ""
问题描述: [Vue warn]: Invalid prop: type check failed for prop "model". Expected Object, got S ...
- linux 基础(7)账号和群组的管理
了解账号和群组的基本信息 账号使用 如何查看 linux 计算机上有哪些账号呢?账号的信息储存在/etc/passwd中,打开就可以看到: less /etc/passwd root:x:0:0:ro ...
- Codeforces Round #851 (Div. 2) A-E
比赛链接 A 题意 给一串只包含 \(1,2\) 的数,找到最小的 \(k\) 使得 \(\prod_{i=1}^k a_i = \prod_{i=k+1}^n a_i\) . 题解 知识点:枚举. ...
- 一种无损更换iPhone手机铃声方案(无需数据线)
iPhone用户手机铃声更换的方案,现在网上已经很多方法,包括使用某思助手.通过iTunes等进行更换,后者现在在MacOS系统中已经不支持.注意️:此文章针对与MacOS系统与IOS搭配使用.Win ...
- P25_wxss - rpx单位
模板样式 - rpx 什么是 rpx 尺寸单位 rpx(responsive pixel)是微信小程序独有的,用来解决屏适配的尺寸单位. rpx 的实现原理 rpx 的实现原理非常简单:鉴于不同设备屏 ...
- JWT的原理及使用
目录 JWT的原理及使用 一.什么是JWT? 二.签发认证流程 三.使用方法 1.设置登录接口 2.设置过期事件 3.定制返回格式 4.配置认证类和权限类 5.写登录逻辑 5.配路由 JWT的原理及使 ...