这篇文章将为大家详细讲解有关Vue如何实现简易翻页效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以创建可维护性和可测试性更强的代码库,Vue允许可以将一个网页分割成可复用的组件,每个组件都包含属于自己的HTML、CSS、JavaScript,以用来渲染网页中相应的地方,所以越来越多的前端开发者使用vue。
源码如下:
<html>
<head> <meta charset="UTF-8">
<title>slidePage</title>
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>
<style type="text/css">
*{
margin: 0;
padding: 0;
}
.container {
width: 100%;
margin: 0 auto;
text-align: center;
}
.content{
font-size: 400px
}
.leftBtn{
width: 45px;
height: 45px;
margin-right: 15px;
}
.rightBtn{
width: 45px;
height: 45px;
margin-left: 15px;
}
</style>
</head>
<body>
<div id='root'>
<div v-if="numberArr.length == 0">{{showMessage}}</div>
<div class="container" v-for="(item, index) in getCurPageContent(numberArr, curPage, itemNumPerPage)" :key="index">
<div class="content">{{item}}</div>
<div class="pageButtonList">
<button class="leftBtn" @click="handleClick('leftBtn')"><</button>
<span class="pagination">{{curPage}}/{{totalPage}}</span>
<button class="rightBtn" @click="handleClick('rightBtn')">></button>
</div>
</div>
</div>
<script>
new Vue({
el: "#root",
data(){
return {
showMessage: 'No number',
content:'',
numberArr: [1, 2, 3, 4],
curPage: 1,
totalPage: 1,
itemNumPerPage: 1
}
},
mounted() {
this.init()
},
methods:{
init(){
this.totalPage = Math.ceil(this.numberArr.length / this.itemNumPerPage)
this.totalPage = this.totalPage < 1 ? 1 : this.totalPage
},
getCurPageContent: function(numberArr, curPage, itemNumPerPage){
return numberArr.filter(function(element, index){
if(index >= (curPage -1)* itemNumPerPage && index < curPage *itemNumPerPage){
return true
}else{
return false
}
})
},
handleClick: function(arg){
if(arg == 'leftBtn'){
this.curPage = this.curPage > 1 ? --this.curPage : this.totalPage
}else if (arg == 'rightBtn'){
this.curPage = this.curPage < this.totalPage ? ++this.curPage: 1
}
}
// handleLeftClick: function(){
// if(this.curPage > 1){
// this.curPage --
// }else{
// this.curPage = this.totalPage
// }
// },
// handleRightClick: function(){
// if(this.curPage < this.totalPage){
// this.curPage ++
// }else{
// this.curPage = 1
// }
// }
}
})
</script>
</body>
</html>
效果如下所示,点击左右能切换页面:
关于“Vue如何实现简易翻页效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。