动态-分页

 <template>
  <div>
      <div class="block">
            <span class="demonstration">大于 7 页时的效果</span>
            <el-pagination
                layout="prev, pager, next"
                :total="pagenum">
            </el-pagination>
       </div>
  </div>
</template>

<script>
import {getlink} from "@/api/getapi.js"
export default {
    mounted(){
        getlink("/api/listdata/tabledata").then((ok)=>{
          
            console.log(ok.data.data.length);
            console.log(Math.ceil(ok.data.data.length/2)*10);
            this.pagenum=Math.ceil(ok.data.data.length/2)*10
        })
    },
    data(){
        return {
            pagenum:0,
        }
    }
}
// 接口动态分页
// 1 拿到接口后得出里面有多少条数据
// 2 然后用得到的数据总长度除以2乘以10——Math.ceil(ok.data.data.length/2)*10
// 3 在设置一个为0的变量,将计算出来的数据条数赋值给他—— this.pagenum=Math.ceil(ok.data.data.length/2)*10
// 4 将这个变量赋值给elementui中的total—— :total="pagenum",此时页数便是动态生成的
</script>

<style>

</style>

点击当前分页展示当前数据

<template>
  <div>
      <div class="block">
            <span class="demonstration">大于 7 页时的效果</span>
            <el-pagination
                layout="prev, pager, next"
                :total="pagenum" @current-change="pagefun">
                <!-- @current-change="pagefun" 该参数表示点击的当前页 
                    在点击时将当前页发给后台
                -->
            </el-pagination>
            <ul>
                <li v-for="(v,i) in arr" :key="i">
                    {{v}}
                </li>
            </ul>
       </div>
  </div>
</template>

<script>
import {getlink} from "@/api/getapi.js"
export default {
    mounted(){
        getlink("/api/listdata/tabledata").then((ok)=>{
          
            console.log(ok.data.data.length);
            console.log(Math.ceil(ok.data.data.length/2)*10);
            this.pagenum=Math.ceil(ok.data.data.length/2)*10
        })
    },
    data(){
        return {
            pagenum:0,
            arr:[
                // {name:"xixi",age:18},
                // {name:"xixi2",age:19},
                // {name:"xixi3",age:20},
                // {name:"xixi4",age:21},
            ]
        }
    },
    methods:{
        pagefun(num){
            console.log(num);
            //    getlink("后台地址","当前点击的页面的下标发送给后台")
              getlink("/api/listdata/pagedata",{num}).then((ok)=>{
                  console.log(ok.data.data);
                //   将下标发给后台后,
                    this.arr=ok.data.data
              })
        }
    }
}
// 接口动态分页
// 1 拿到接口后得出里面有多少条数据
// 2 然后用得到的数据的length除以2乘以10——Math.ceil(ok.data.data.length/2)*10
// 3 在设置一个为0的变量,将计算出来的数据条数赋值给他—— this.pagenum=Math.ceil(ok.data.data.length/2)*10
// 4 将这个变量赋值给elementui中的total—— :total="pagenum"

// 点击展示当前分页
// 1,找到elementui中的点击事件@current-change(表示点击当前页)
// 2,将点击的当前页的下标传给后台
// 3,在将得到的数据遍历展示在页面,这样每次点击时每个分页都会展示自己的数据
</script>

<style>

</style>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis-plus的动态分页查询可以通过使用插件提供的分页机制来实现。首先,你需要在配置类中添加分页插件的配置。具体的配置类代码如下所示: ```java package com.hxstrive.mybatis_plus; import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class MybatisPlusConfig { /** * 分页插件。如果你不配置,分页插件将不生效 */ @Bean public MybatisPlusInterceptor paginationInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); // 指定数据库方言为 MYSQL interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return interceptor; } } ``` 这段代码中,我们创建了一个MybatisPlusInterceptor对象,并添加了PaginationInnerInterceptor作为内部拦截器,指定了数据库方言为MySQL。这样就完成了分页插件的配置。 接下来,你可以在你的Mapper接口中使用Mybatis-plus提供的分页查询方法来进行动态分页查询。示例代码如下所示: ```java import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.hxstrive.mybatis_plus.entity.User; import org.apache.ibatis.annotations.Param; public interface UserMapper { /** * 动态分页查询用户 * * @param page 分页参数 * @param age 年龄 * @return 用户列表 */ IPage<User> selectUserByAge(Page<User> page, @Param("age") Integer age); } ``` 在上面的示例代码中,我们使用了Mybatis-plus提供的IPage和Page类来实现动态分页查询。你可以通过传入Page对象和其他的查询条件来进行分页查询。 总结起来,Mybatis-plus的动态分页查询需要配置分页插件,并在Mapper接口中使用相应的分页方法来实现。这样就可以实现根据条件动态进行分页查询了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Mybatis-plus的分页查询](https://blog.csdn.net/weixin_46213083/article/details/125258551)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值