>  기사  >  웹 프론트엔드  >  bootstrap-table이 서버 페이징을 구현하는 방법

bootstrap-table이 서버 페이징을 구현하는 방법

巴扎黑
巴扎黑원래의
2017-09-02 13:47:371496검색

이 글에서는 주로 서버 페이징(스프링 백엔드)을 구현하기 위한 부트스트랩 테이블의 예를 소개합니다. 관심 있는 분들은 이에 대해 알아볼 수 있습니다.

최근에는 부트스트랩 테이블 플러그인을 사용합니다. .클라이언트 측 페이징의 경우 볼륨 1과 다수 사이의 상호 작용이 좋지 않으므로 서버 측에서 대량의 데이터를 페이징하는 데 사용됩니다. 부트스트랩 테이블의 기본 페이징 매개변수가 무엇인지 살펴보세요

어떤 첨자를 오프셋으로 지정해야 합니까? 시작

    limit 페이지당 제한 수
  • 는 기본 페이징 매개변수와 다를 수 있습니다. 그래서 배경에 전달되는 매개변수는
  • page입니다. 페이지 수는 0
부터 시작합니다.

    size 각 페이지에 표시되는 숫자
  •   $('#' + tableId).bootstrapTable({
    
         queryParams: function (e) { 
          var param = { 
           size: e.limit, 
           page: (e.offset / e.limit),//不需要+1 
           
          }; 
          return param; 
         },
         sidePagination:“server”;
    });

    Backend


 @ApiOperation(value = "获取企业列表,支持分页", notes = "json方法获取用户列表")
 @ApiImplicitParams({ @ApiImplicitParam(name = "name", value = "企业名称", required = true, dataType = "string"),
 @ApiImplicitParam(name = "beginTime", value = "开始时间", required = true, dataType = "string") })
 @RequestMapping(value="/list",method=RequestMethod.POST)
 @ResponseBody
 public Map<String,Object> list(@RequestParam Map<String,Object> map,@RequestParam(required = false) String name, @RequestParam(required = false) String beginTime, @RequestParam(required = false) String endTime, @RequestParam(required = false) Integer deptid){
  List<Map<String,Object>> list = new ArrayList<>();
  //当前页数
  int page = map.get("page")== null ? 0 : Integer.parseInt(map.get("page").toString());
  // 每页行数
  int size = map.get("size") == null ? 10 : Integer.parseInt(map.get("size").toString());
  Order order = new Order(Direction.ASC,"id");
  Order order1 = new Order(Direction.DESC,"createTime");
  List<Order> orders = new ArrayList<Order>();
  orders.add(order1);//先按照createTime 降序排序 然后按照id升序
  orders.add(order);
  Sort sort = new Sort(orders);
  Pageable pageable = new PageRequest(page,size,sort);
  Page<Company> companyPages = null;
  if(StringKit.isEmpty(name)){
   companyPages = companyService.companyDao.findAll(pageable);
  }else{
   companyPages = companyService.companyDao.findByNameLike(name,pageable);
  }

  List<Company> companyList = companyPages.getContent();
  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  for(Company company:companyList){
   Map<String,Object> mapTemp = BeanKit.describe(company);
   mapTemp.put("createTime", sdf.format(company.getCreateTime()));
   list.add(mapTemp);
  }
   Map<String,Object> data = new HashMap<String,Object>();
   data.put("total", companyPages.getTotalElements());
   data.put("rows", list);
  return data;
 }

Notes


부트스트랩 테이블에서 받은 매개변수에는 합계와 행이 있어야 하며, 합계는 총 수량, 행은 각 페이지의 수입니다.

렌더링 표시

위 내용은 bootstrap-table이 서버 페이징을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.