vue分页组件动态页码_怎样分页设置页码

vue分页组件动态页码_怎样分页设置页码效果如下:HTML:<ulclass=”pagef16tcmt30″><li><spanv-if=”page>1″><b@click=”page–,pageClick()”>上一页</b></span><spanv-if=”page==1″>上一页</span><spanv-for=”indexinpagesAll”:key=”index”.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

效果如下:

vue分页组件动态页码_怎样分页设置页码

HTML:

<ul class="page f16 tc mt30">
<li>
<span v-if="page > 1"><b @click="page--,pageClick()">上一页</b></span>
<span v-if="page == 1">上一页</span>
<span v-for="index in pagesAll" :key="index" :class="{'active':page == index}" @click="goPage(index)">{
  
  {index}}</span>
<span v-if="page!=pageAll"><b @click="page++,pageClick()">下一页</b></span>
<span v-if="page == pageAll">下一页</span>
</li>
<li>共{
  
  {pageAll}}页</li>
<li>到<input type="text" class="int02" v-model="jumpPage"> 页<input type="button" class="bt03" value="确定" @click="goPage(jumpPage)"></li>
</ul>

CSS:

.page li{display:inline-block;margin:0 5px;}
.page li span{display:inline-block;padding:5px 10px;border:1px solid #dfdfdf;margin:0 5px;border-radius:5px;cursor:pointer;}
.page li span.active,.page li span:hover{border:1px solid #316dd9;background:#316dd9;color:#fff;}
.page b{display:block;font-weight:normal;}
.page .int02,.page .bt03{line-height:32px;border:1px solid #ccc;vertical-align:middle;margin:0 10px;border-radius:5px;}
.page .int02{width:40px;text-align:center;}
.page .bt03{background:#316dd9;color:#fff;border:none;padding:0 30px;line-height:36px;margin-left:20px;}

JS:

data(){
    return{
      listData:"",//旅行社列表数据搜索结果数据
      // pageSize:15, //每页个数,后台默认15
      page:1,//当前页码,不传默认第一页
      pageAll:"", //数据总页数
      jumpPage:"",//跳转页码
    }
},
methods:{
    //获取旅行社列表数据 keywords words搜索关键字,region_id id区域id,page onPage当前页码
    getTravel(event){
    
    ....数据列表获取.....
 
        if (response.data.status==1) {
            console.log(response.data.data);
            this.pageAll = response.data.data.count;
            this.listData = response.data.data.data;
        }else{
            console.log(response.data.info);
        }

    ....数据列表获取.....

    },
    //点击上一页下一页
    pageClick(){       
      this.getTravel(this.page); //获取列表数据 
      window.scrollTo(0,500); //页面滚动到顶部
    },
    //点击页码或跳转指定页码
    goPage(event){
      if(event != this.page && event != ""){
        this.page = event
        this.getTravel(this.page); //获取列表数据
        window.scrollTo(0,500); //页面滚动到顶部
      }
    },
      
},
computed: {
    pagesAll(){
        // 开始数字
        var leftNum = 1;
        // 结束数字
        var rightNum = this.pageAll;
        // 存储页码数组
        var pageArray = [];
        // 显示页码的数量 最好是个单数
        var showNum = 5;
        // 因为是单数向上取整获取到中间的数字
        var centerNum = Math.ceil(showNum/2);
        // 判断分析当总页数超过showNum展示页数时,需要判断分页情况
        //1、在最左边第一个或者在centerNum的前面
        //2、在中间
        //3、最右边最后一个
        if(this.pageAll >= showNum){	
            // 中间centerNum时左右都加上(centerNum-1)
            if(this.page > centerNum && this.page < this.pageAll - (centerNum - 1)){
                //一定要用Number格式化一下获取的数据,防止获取的是字符串而不是数字
                leftNum = Number(this.page) - (centerNum - 1)
                rightNum = Number(this.page) + (centerNum - 1)
            }else{
              //最左边或者在showNum的中间
              if(this.page <= centerNum){
                leftNum = 1
                rightNum = showNum
                // 最右边时结束是总条数,开始是showNum减去1
              }else{
                rightNum = this.pageAll
                leftNum = this.pageAll - (showNum - 1)
              }
           }
        }
        while (leftNum <= rightNum){
            pageArray.push(leftNum)
            leftNum ++
	    }
        return pageArray
    }
  } 

 划重点:

获取过来的页码数据一定要用Number()格式化一下!防止获取的是字符串而不是数字!T_T

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/194127.html原文链接:https://javaforall.net

(0)
上一篇 2025年11月11日 下午11:01
下一篇 2025年11月11日 下午11:43


相关推荐

  • python怎么判断质数和合数_什么是质数和合数以及判断方法介绍

    python怎么判断质数和合数_什么是质数和合数以及判断方法介绍第一 什么是质数和合数的概念什么是质数和合数 属于数学范畴的问题了 在 excel 中如果需要统计 100 以内的质数 首先得明白什么是质数和合数 其概念是什么 简单理解 除 1 以外任意正整数整除则为合数 反之为质数 1 既不是质数也不是合数 2 3 都是质数 除此外如果一个数能被 2 到小于其开方的最大整数整除 则为合数 否则为质数 第二 质数和合数判断了解了什么是质数和合数之后 我们可以在 Excel 中使用公式判

    2026年3月17日
    2
  • 什么是Python迭代器?

    什么是Python迭代器?迭代器 Iterator 迭代器可以看作是一个特殊的对象 每次调用该对象时会返回自身的下一个元素 从实现上来看 一个迭代器对象必须是定义了 iter 方法和 next 方法的对象 Python 的 Iterator 对象表示的是一个数据流 可以把这个数据流看做是一个有序序列 但我们却不能提前知道序列的长度 所以 Iterator 的计算是惰性的 只有在需要返回下一个数据时它才会计算 Iter

    2026年3月18日
    2
  • LDAP协议介绍[通俗易懂]

    LDAP协议介绍[通俗易懂]LDAP协议基础概念 1.从用途上阐述LDAP,它是一个存储静态相关信息的服务,适合“一次记录多次读取”。常用LDAP服务存储的信息: 公司的物理设备信息(如打印机,它的IP地址、存放位置、厂商、购买时间等)公开的员工信息(地址、电话、电子邮件…)合同和账号信息(客户信息、产品交付日期、投标信息、项目信息…)凭证信息(认证凭证、许可证凭证…)2

    2025年6月16日
    5
  • ubuntu clion 激活码【在线注册码/序列号/破解码】

    ubuntu clion 激活码【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月19日
    37
  • vscode格式化代码(绝对好用,亲测)

    vscode格式化代码(绝对好用,亲测)本人参考了二者的部分内容 进行了结合总结 感谢二位第一位 地址太长 就不直接写地址了第二位 地址太长 就不直接写地址了下载对应插件 可以观测到哪里不规范 1 代码格式化为 eslint 风格 2 HTML 格式化代码缩进此时可以看到代码哪里不规范 哪里有红线网络上说 1 alt shit f 可以格式化代码 2 直接 ctrl s 保存后就自动格式化代码 本人测试后发现有些问题 多逗号 分号等的东西 可能是我还缺啥配置导致快捷键不太好用吧 于是我增加了一些配置 支持了 2 ctrl s 后自动格式化代码增加

    2026年3月17日
    3
  • apimodelproperty注解不生效(注解是什么)

    https://blog.csdn.net/weixin_44356055/article/details/109451892

    2022年4月14日
    481

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号