pagehelper5 + mybatis3 + vue.js + layerpage 实现异步分页 (有源码)

pagehelper5 + mybatis3 + vue.js + layerpage 实现异步分页 (有源码)

所需jar包以及js下载地址密码: fukj

这是我自己做的一个示例

配置文件

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <property name="mapperLocations">
        <array>
            <value>classpath:mapper/*.xml</value>
        </array>
    </property>
    <property name="typeAliasesPackage" value="com.isea533.mybatis.model"/>
    <property name="plugins">
        <array>
            <bean class="com.github.pagehelper.PageInterceptor">
                <!-- 这里的几个配置主要演示如何使用,如果不理解,一定要去掉下面的配置 -->
                <property name="properties">
                    <value>
                        helperDialect=mysql
                        reasonable=true
                        supportMethodsArguments=true
                        params=count=countSql
                        autoRuntimeDialect=true
                    </value>
                </property>
            </bean>
        </array>
    </property>
</bean>

Dao层

数据交互层使用接口,然后使用mybatis 通过xxxMapper.xml 文件去实现接口
这里我使用了List<Map>去接收了数据库的数据,也可以是用Bean也就是PoJo 类去接收数据映射都没有问题,只是我懒得去写PoJo了所以就用Map 代替了效果都是一样的。

package cn.yrgequene.dao.user;

import java.util.List;
import java.util.Map;
/**
*用户 DAO 数据交互层
*@author yrge
*/
public interface UserDao {
    /**
     * 查询所有的用户
     * @return
     * @throws Exception
     */
    public List<Map<String, Object>> findAll() throws Exception;
}

Mapper.xml

mybatisXml 文件这里就是一个简单查询查询了所有的用户信息

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.yrgequene.dao.user.UserDao">
    
    <select id="findAll">
        SELECT * FROM user
    </select>
    
</mapper> 

service 层 接口

service层的接口 这里使用了 pagehelper物理分页进行分页,也可以在controller层分页但是官方以及我个人都建议在service层 ,分层做事好管理好定位。

package cn.yrgequene.service.User;

import java.util.Map;

import org.springframework.stereotype.Service;

import com.github.pagehelper.PageInfo;
/**
 * 用户的service 接口
 * @author yrge
 *
 */

@Service
public interface IUserService{
    /**
     * 查询所有的用户
     * @param pageNum
     * @param pageSize
     * @return
     * @throws Exception
     */
    public PageInfo<Map<String, Object>> findAll(Integer pageNum,Integer pageSize) throws Exception;
}

service 层实现

注释写的很详细,这里就不废话了。

package cn.yrgequene.service.User.impl;

import java.util.List;
import java.util.Map;

import org.springframework.beans.factory.annotation.Autowired;

import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;

import cn.yrgequene.dao.user.UserDao;
import cn.yrgequene.service.BaseService;
import cn.yrgequene.service.User.IUserService;
/**
 * 用户的server 实现层
 * @author yrge
 */
public class UserService extends BaseService implements IUserService {
    @Autowired
    private UserDao userDao;
    /**
     * 查询出所有数据
     */
    @Override
    public PageInfo<Map<String, Object>> findAll(Integer pageNum,Integer pageSize) throws Exception {
        PageHelper.startPage(pageNum,pageSize);//开始分页,物理分页
        List<Map<String, Object>> list = userDao.findAll();//DB操作查询数据
        PageInfo<Map<String, Object>> pageInfo=new PageInfo<Map<String,Object>>(list); //将查询到的数据封装到List中
        return pageInfo;
    }

}

controller 控制层

controller控制层 因为没有使用shrio安全控件所以我将jsp页面放在了WEB-INF目录下要用controller去跳转到jsp 页面

package cn.yrgequene.controller.user;

import java.io.PrintWriter;
import java.util.Map;

import javax.servlet.http.HttpServletResponse;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import com.github.pagehelper.PageInfo;

import cn.yrgequene.controller.BaseController;
import cn.yrgequene.service.User.IUserService;
import net.sf.json.JSONObject;
@Controller
@RequestMapping(value="user")
public class UserController extends BaseController{
    @Autowired
    private IUserService userService;
    
    @RequestMapping(value="page_test")
    public String topageTest(){
        return "/page_test";
    }
    
    @RequestMapping(value="list")
    public void findAll(Integer pageNum,HttpServletResponse response){
        try {
            PageInfo<Map<String, Object>> pageInfo=userService.findAll(pageNum, 10);
            JSONObject jsonObject=new JSONObject();
            jsonObject.put("pageInfo", pageInfo);
            response.setContentType("text/html;charset=utf-8");
            PrintWriter out=response.getWriter();
            out.println(jsonObject.toString());
            out.flush();
            out.close();
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}

**jsp **

为了方便路径我使用了jsp文件,也可以使用HTML,实现方式一样。

v-for vue 框架的循环 这个id=for_w标识是告诉 vue 插件自己的作用范围 后面JS文件会有一个el就是写这个,接着往后看。


<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <link rel="stylesheet" type="text/css" href="${base_path}/static/static/h-ui/css/H-ui.min.css" />
    <link rel="stylesheet" type="text/css" href="${base_path}/static/lib/Hui-iconfont/1.0.8/iconfont.css" />
    <link rel="stylesheet" type="text/css" href="${base_path}/static/static/h-ui/css/H-ui.reset.css" />
    <link rel="stylesheet" type="text/css" href="${base_path}/static/static/h-ui/css/index.css" />
    <link rel="stylesheet" type="text/css" href="${base_path}/static/static/h-ui/css/laypage.css" />
    <style type="text/css">
        .mt-200{
            margin-top:10%;
        }
        
        #page1{
        margin-top:20px;
        margin-left:35%;
    }
    </style>
    <title>分页测试</title>
</head>
<body>
<div class="page-container">
    
    <table class="table table-border table-bordered table-bg radius table-hover mt-200">
        <thead class="text-c">
        <tr">
            
            <th>编号</th>
            <th>姓名</th>
            <th>年龄</th>
            <th>性别</th>
            <th>爱好</th>
        </tr>
         
        </thead>
        <tbody id="for_w">
        <tr class="text-c" v-for="value in json">
            <td style="width:20%;overflow-x:hidden;overflow-y:hidden;">{{value.id}}</td>
            <td style="width:20%;overflow-x:hidden;overflow-y:hidden;">{{value.user_name}}</td>
            <td style="width:20%;overflow-x:hidden;overflow-y:hidden;">{{value.user_age}}</td>
            <td style="width:20%;overflow-x:hidden;overflow-y:hidden;">{{value.user_sex}}</td>
            <td style="width:20%;overflow-x:hidden;overflow-y:hidden;">{{value.user_hobby}}</td>
        </tr>
       

        </tbody>
    </table>
    
<div id="page1" ></div>

</div>
<script src="${base_path}/static/lib/jquery/1.9.1/jquery.min.js"></script>
<script src="${base_path}/static/lib/layer/2.4/layer.js"></script>
<script src="${base_path}/static/static/h-ui/js/laypage.js"></script>
<script src="${base_path}/static/static/h-ui/js/vue1.0.28.js"></script>
<script src="${base_path}/static/static/h-ui/js/page.js"></script>

</body>
</html>

js 文件

使用了 layerpage 的插件,膜拜下贤心大神 哈哈 大概就是这样大家有什么疑问可以在下面留言。


//以下将以jquery.ajax为例,演示一个异步分页

/*
 * 实例化 Vue
 */
 var vm =new Vue({
                el:'#for_w',   //刚才说到的for_w
                data: { 
                    json: []   //定义一个空的json
                }
              });
function demo(curr){
    $.ajax({
        url:"list.action",
        type:"POST",
        data:{
            "pageNum":curr||1,
        },
        dataType:"json",
        success:function(data){
            $("#addjson").empty();
            var json=eval(data)
            vm.json =json.pageInfo.list  //给 json 赋值
            //显示分页
            laypage({
              cont: 'page1', //容器。值支持id名、原生dom对象,jquery对象。【如该容器为】:<div id="page1"></div>
              pages: json.pageInfo.pages, //通过后台拿到的总页数
              curr: curr || 1, //当前页
              jump: function(obj, first){ //触发分页后的回调
                if(!first){ //点击跳页触发函数自身,并传递当前页:obj.curr
                  demo(obj.curr);
                }
              }
            });
        },
        error:function(er){
            layer.msg("服务器出错,请重试!"+console.log(er));
            console.log(er)
        }
          });
        };

//运行
demo();

这是源码密码: pcun

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,509评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,806评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,875评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,441评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,488评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,365评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,190评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,062评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,500评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,706评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,834评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,559评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,167评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,779评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,912评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,958评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,779评论 2 354

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,631评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 3,811评论 0 11
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,654评论 18 139
  • 又是一年春天,万物复苏,大地也醒了过来。也正是这个季节,使我想起了那年春醒…… 我叫奇迹,他叫沉...
    aSisuer阅读 208评论 0 1
  • 一个人走在校园的路上,冷飕飕的风把我吹的全身裹在衣服里,根本来不及关心身边又路过了谁。 我忽然间想到毕淑敏说过的一...
    年小暖阅读 1,947评论 112 106