<template>
<view>
<view class="ul">
<view v-if='curpage>1' @click="curpage--,pageClick()" class="but">上一页</view>
<view v-if='curpage==1' class="but">上一页</view>
<view class="num" @click="btnClick(i)" :class="{'active':curpage==i}" v-for="i in indexs" :key="i">{{i}}</view>
<view @click="curpage++,pageClick()" v-if='curpage!=allNum' class="but">下一页</view>
<view v-if='curpage==allNum' class="but">下一页</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
index:1,
allNum:20,
curpage:1,
totalPage:0
}
},
methods: {
pageClick(){
// this
console.log(this.curpage)
},
btnClick(i){
if(this.curpage!=i){
this.curpage=i
}
}
},
computed:{
indexs:function(){
let that=this;
let left=1;
let right=this.allNum;
let arr=[];
if(that.allNum>=5){
if(that.curpage>3&&that.curpage<that.allNum-2){
left=that.curpage-2;
right=that.curpage+2;
}else{
if(that.curpage<=3){
left=1;
right=5;
console.log(66666666666)
}else{
left=that.allNum-4;
right=that.allNum
console.log(777777777777)
}
}
}
while(left<=right){
arr.push(left)
left++
}
return arr
}
}
}
</script>
<style>
.ul{
width: 100vw;
display: flex;
}
.but{
width:100px;
height: 20px;
}
.num{
width:80px;
text-align: center;
}
.but,.num{
border: 1px solid rgba(0,0,0,.2);
height: 50px;
line-height: 50px;
text-align: center;
margin: 0 6px;
font-size: 14px;
}
.active{
background-color: #337AB7;
color: white;
}
</style>
vue实现分页
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...