移动端滑动效果 swiper 4.0.7

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>每日优鲜</title>
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" />
<link rel="stylesheet" href="css/swiper.min.css">
<!-- <link rel="stylesheet" href="css/style.css"> -->
<style type="text/css">
html,body {
position:relative;
height:100%;
}
html {
overflow:hidden;
}
* {
padding:0;
margin:0;
}
li {
list-style:none;
}
body {
background:#fff;
font-family:Helvetica Neue,Helvetica,Arial,sans-serif;
font-size:12px;
}
.img img {
width:100%;
display:block;
}
#top {
position:absolute;
top:0;
z-index:5;
width:100%;
background:#fff;
}
#top .addr {
height:36px;
margin:0 auto;
display:block;
}
#top .search {
position:absolute;
top:0;
right:0;
height:36px;
display:block;
}
#nav {
border-bottom:1px solid #ebebeb;
}
#nav .swiper-slide span {
margin:0 5px;
text-align:center;
display:block;
line-height:2.5;
font-size:14px;
color:#333333;
}
#nav .bar {
width:50px;
height:3px;
position:absolute;
bottom:0px;
}
#nav .bar .color {
width:36px;
margin:0 auto;
height:3px;
background:#ff4891;
}
.banner img {
width:100%;
display:block;
}
.banner .swiper-pagination {
left:auto;
right:7px;
bottom:7px;
width:auto;
padding:2px 7px;
border-radius:10px;
color:#fff;
background:rgba(0,0,0,.3);
}
#page {
margin-bottom:50px;
height:100%;
}
#page .slidepage {
height:100%;
}
.scroll {
height:100%;
}
.slidescroll {
height:auto;
}
#footer {
position:fixed;
bottom:0;
z-index:5;
}

</style>
</head>
<body>
<div id="top">
<img src="images/top.png" class="addr">
<img src="images/search.png" class="search">
<div class="swiper-container" id="nav">
<div class="swiper-wrapper">
<div class="swiper-slide">
<span style="color:rgba(255,72,145,1);">热卖</span></div>
<div class="swiper-slide">
<span>水果</span></div>
<div class="swiper-slide">
<span>乳品</span></div>
<div class="swiper-slide">
<span>零食</span></div>
<div class="swiper-slide">
<span>肉蛋</span></div>
<div class="swiper-slide">
<span>蔬菜</span></div>
<div class="swiper-slide">
<span>酒饮</span></div>
<div class="swiper-slide">
<span>速食</span></div>
<div class="swiper-slide">
<span>熟食</span></div>
<div class="swiper-slide">
<span>水产</span></div>
<div class="swiper-slide">
<span>粮油</span></div>
<div class="swiper-slide">
<span>轻食</span></div>
<div class="swiper-slide">
<span>火锅</span></div>
<div class="swiper-slide">
<span>日百</span></div>
<div class="bar">
<div class="color"></div>
</div>
</div>
</div>
</div>

<div class="swiper-container" id="page">
<div class="swiper-wrapper">
<!-- 一 -->
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">
<!-- 热卖 -->
<div class="swiper-container banner">
<div class="swiper-wrapper">
<div class="swiper-slide">
<img src="uploads/banner1.jpg"></div>
<div class="swiper-slide">
<img src="uploads/banner2.jpg"></div>
<div class="swiper-slide">
<img src="uploads/banner3.jpg"></div>
</div>
<div class="swiper-pagination"></div>
</div>

<div class="img">
<img src="images/index1.png">
<img src="images/hot.png">
</div>

<ul class="img">
<li>
<img src="uploads/product1.png"></li>
<li>
<img src="uploads/product2.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
</ul>

<div class="img">
<img src="images/bottom.png">
</div>

</div>
</div>
</div>
</div>

<!-- 二 -->
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">
<div class="swiper-container banner">
<div class="swiper-wrapper">
<div class="swiper-slide">
<img src="uploads/banner1.jpg"></div>
<div class="swiper-slide">
<img src="uploads/banner2.jpg"></div>
<div class="swiper-slide">
<img src="uploads/banner3.jpg"></div>
</div>
<div class="swiper-pagination"></div>
</div>
<div class="img">
<img src="images/hot.png"></div>
<ul class="img">
<li>
<img src="uploads/product1.png"></li>
<li>
<img src="uploads/product2.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
<li>
<img src="uploads/product3.png"></li>
<li>
<img src="uploads/product4.png"></li>
<li>
<img src="uploads/product5.png"></li>
</ul>
<div class="img">
<img src="images/bottom.png"></div>
</div>
</div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide3</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide4</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide5</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide6</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide7</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide8</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide9</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide10</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide11</div></div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide12</div>
</div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide13</div>
</div>
</div>
</div>
<div class="swiper-slide slidepage">
<div class="swiper-container scroll">
<div class="swiper-wrapper">
<div class="swiper-slide slidescroll">slide14</div>
</div>
</div>
</div>
</div>
</div>
<div class="img" id="footer"><img src="images/footer.png"></div>
<script src="js/swiper.min.js"></script>
<script>
//暂时设计每个slide大小需要一致
barwidth = 36 //导航粉色条的长度px
tSpeed = 300 //切换速度300ms
var navSwiper = new Swiper(‘#nav‘, {
slidesPerView: 6,
freeMode: true,
on: {
init: function() {
navSlideWidth = this.slides.eq(0).css(‘width‘); //导航字数需要统一,每个导航宽度一致
bar = this.$el.find(‘.bar‘)

bar.css(‘width‘, navSlideWidth)
bar.transition(tSpeed)
navSum = this.slides[this.slides.length - 1].offsetLeft //最后一个slide的位置

clientWidth = parseInt(this.$wrapperEl.css(‘width‘)) //Nav的可视宽度
navWidth = 0
for (i = 0; i < this.slides.length; i++) {
navWidth += parseInt(this.slides.eq(i).css(‘width‘))
}

topBar = this.$el.parents(‘body‘).find(‘#top‘) //页头

},

},
});

var pageSwiper = new Swiper(‘#page‘, {
watchSlidesProgress: true,
resistanceRatio: 0,
on: {
//左右拖动内容页
touchMove: function() {
progress = this.progress

bar.transition(0)
bar.transform(‘translateX(‘ + navSum * progress + ‘px)‘)
//粉色255,72,145灰色51,51,51

for (i = 0; i < this.slides.length; i++) {
slideProgress = this.slides[i].progress
if (Math.abs(slideProgress) < 1) {
r = Math.floor((255 - 51) * (1 - Math.pow(Math.abs(slideProgress), 2)) + 51)
g = Math.floor((72 - 51) * (1 - Math.pow(Math.abs(slideProgress), 2)) + 51)
b = Math.floor((145 - 51) * (1 - Math.pow(Math.abs(slideProgress), 2)) + 51)
navSwiper.slides.eq(i).find(‘span‘).css(‘color‘, ‘rgba(‘ + r + ‘,‘ + g + ‘,‘ + b + ‘,1)‘)
}
}
},

transitionStart: function() {
//内容页id
activeIndex = this.activeIndex
console.log(activeIndex);
activeSlidePosition = navSwiper.slides[activeIndex].offsetLeft
//释放时导航粉色条移动过渡
bar.transition(tSpeed)
bar.transform(‘translateX(‘ + activeSlidePosition + ‘px)‘)
//释放时文字变色过渡
navSwiper.slides.eq(activeIndex).find(‘span‘).transition(tSpeed)
navSwiper.slides.eq(activeIndex).find(‘span‘).css(‘color‘, ‘rgba(255,72,145,1)‘)
if (activeIndex > 0) {
navSwiper.slides.eq(activeIndex - 1).find(‘span‘).transition(tSpeed)
navSwiper.slides.eq(activeIndex - 1).find(‘span‘).css(‘color‘, ‘rgba(51,51,51,1)‘)
}
if (activeIndex < this.slides.length) {
navSwiper.slides.eq(activeIndex + 1).find(‘span‘).transition(tSpeed)
navSwiper.slides.eq(activeIndex + 1).find(‘span‘).css(‘color‘, ‘rgba(51,51,51,1)‘)
}
//导航居中
navActiveSlideLeft = navSwiper.slides[activeIndex].offsetLeft //activeSlide距左边的距离

navSwiper.setTransition(tSpeed)
if (navActiveSlideLeft < (clientWidth - parseInt(navSlideWidth)) / 2) {
navSwiper.setTranslate(0)
} else if (navActiveSlideLeft > navWidth - (parseInt(navSlideWidth) + clientWidth) / 2) {
navSwiper.setTranslate(clientWidth - navWidth)
} else {
navSwiper.setTranslate((clientWidth - parseInt(navSlideWidth)) / 2 - navActiveSlideLeft)
}

},
}
});

navSwiper.$el.on(‘touchstart‘, function(e) {
e.preventDefault() //去掉按压阴影
})

//点击nav 标题
navSwiper.on(‘tap‘, function(e) {

clickIndex = this.clickedIndex
clickSlide = this.slides.eq(clickIndex)

pageSwiper.slideTo(clickIndex, 0);
this.slides.find(‘span‘).css(‘color‘, ‘rgba(51,51,51,1)‘);
clickSlide.find(‘span‘).css(‘color‘, ‘rgba(255,72,145,1)‘);
})

//内容上下滚动
var scrollSwiper = new Swiper(‘.scroll‘, {
//65是头部的高
//36是top地址和搜索的高

slidesOffsetBefore: 72,
direction: ‘vertical‘,
freeMode: true,
slidesPerView: ‘auto‘,

/*mousewheel: {
releaseOnEdges: true,
},
on: {

//上下滑动
touchMove: function() {

if (this.translate > 72 - 36 && this.translate < 72) {
topBar.transform(‘translateY(‘ + (this.translate - 72) + ‘px)‘);
}

},
//开始滑动
touchStart: function() {
startPosition = this.translate
//上下的位置
console.log(startPosition);
},

//滑动成功后的
touchEnd: function() {
topBar.transition(tSpeed)
console.log(topBar);
if (this.translate > 36 && this.translate < 72 && this.translate < startPosition) {
topBar.transform(‘translateY(-36px)‘);
for (sc = 0; sc < scrollSwiper.length; sc++) {
if (scrollSwiper[sc].translate > 36) {
scrollSwiper[sc].setTransition(tSpeed);
scrollSwiper[sc].setTranslate(36)
}
}
}
if (this.translate > 36 && this.translate < 72 && this.translate > startPosition) {
topBar.transform(‘translateY(0px)‘);
for (sc = 0; sc < scrollSwiper.length; sc++) {
if (scrollSwiper[sc].translate < 72 && scrollSwiper[sc].translate > 0) {
scrollSwiper[sc].setTransition(tSpeed);
scrollSwiper[sc].setTranslate(72)
}
}
}
},

transitionStart: function() {

topBar.transition(tSpeed)
if (this.translate < 72 - 36) {
topBar.transform(‘translateY(-36px)‘);
if (scrollSwiper) {
for (sc = 0; sc < scrollSwiper.length; sc++) {
if (scrollSwiper[sc].translate > 36) {
scrollSwiper[sc].setTransition(tSpeed);
scrollSwiper[sc].setTranslate(36)
}
}
}

} else {
topBar.transform(‘translateY(0px)‘);
if (scrollSwiper) {
for (sc = 0; sc < scrollSwiper.length; sc++) {
if (scrollSwiper[sc].translate < 72 && scrollSwiper[sc].translate > 0) {
scrollSwiper[sc].setTransition(tSpeed);
scrollSwiper[sc].setTranslate(72)
}
}
}
}
},
}*/

})

//热卖
var bannerSwiper = new Swiper(‘.banner‘, {
loop: true,
pagination: {
el: ‘.swiper-pagination‘,
type: ‘fraction‘,
renderFraction: function(currentClass, totalClass) {
return ‘<span class="‘ + currentClass + ‘"></span>‘ + ‘/‘ + ‘<span class="‘ + totalClass + ‘"></span>‘;
},
},
});
</script>
</body>
</html>

原文地址:https://www.cnblogs.com/shenjilin/p/8944788.html

时间: 2024-08-30 04:05:05

移动端滑动效果 swiper 4.0.7的相关文章

做微信公众号时,移动端滑动效果(swiper插件(display:none))显示滑动问题

微信公众号的制作,其中缺少不了希望实现标题.内容.图片的滑动效果, 这时候可以选择使用(swiper插件)实现相应效果,功能十分强大,链接:http://www.swiper.com.cn/: 最近做一款公众号时,在实现功能时遇到一难点,废了九牛二虎之力,终于在一高人的帮助下解决了. 1.问题描述: 原本该滑动项是隐藏的(display:none;),滑动项的代码是参考swiper插件文档内容而写, 通过按钮点击之后该滑动项显示(dispay:block),再进行左右滑动效果时,始终显示swip

移动端滑动插件 swiper

swiper.js能适用于用PC网页,也能使用移动端页面,之前用TouchSwipe,感觉没有swiper.js强大,TouchSwipe有一个bug,在滑动区域有连接的时候(大面积的a),默认点击会无效,只能滑动,即时用jq去模拟点击也是失效的,也许是自己没有发现正确使用方法,求问度娘,发现swiper神器... 下面放上代码, //滑动效果 var swiper = new Swiper('.swiper-container', { pagination: '.swiper-paginati

移动端触摸滑动插件Swiper

移动端触摸滑动插件Swiper 04/02/2015 一.了解Swiper 目前移动端项目一般都需要具有触屏焦点图的效果,如果你也需要实现这一功能的话,Swiper是一个不错的选择. 1.他不需要加载任何公共库(如jQuery)即可运行,这保证了Swiper的轻量和运行速度.Swiper也可以在加载了公共库的环境下安全的动行,如jQuery,Zepto,jQuery Moblie等. 2.Swiper默认的触摸比例为1:1,你可以通过修改Swiper的设置来改变这个比例. 3.Swiper 增加

初试 vue2.0——9.项目开发_better-scroll 实现移动端滑动2

写在前面的话: 上一篇文章实现了滑动效果,这部分来试试左右联动效果的实现方法吧 九.better-scroll + vue2.0 实现移动端滑动2--左右联动 效果:滑动右侧时,左侧也能有相应的变化:点击左侧时,右侧也能自动定位到相应的位置. 如下图所示界面,左侧为分栏,右侧为分栏详情. 滑动右边使左边联动的大概的思路: 1)要知道右侧的列表中,每一个分栏所占的高度,存进一个数组中. 2)实现左边联动,则必须要监控 "scroll"事件,获取其高度 3)将scroll 的高度与右侧分栏

如何实现微信5.0的滑动效果

作为初学者,虽然深知不可一步登天也应当脚踏实地,但是总会有一些奇思异想想要去实现.在实现第一个app的时候我们遇到的另一个头疼的问题便是如何实现像微信5.0版本过后的滑动效果,查阅官方文档以及借鉴网上大神的经验之后我们也顺利得到了一点思路.虽然我另外一个伙伴已经实现了此功能,但我总觉得有些许的冗杂,经过研究学习之后现在已经得到了优化,详见下文. 1.android.support.v4 google提供了Android Support Library package 系列的包来保证来高版本sdk

android用最简单的方法实现QQ5.0的侧边栏滑动效果

先看个效果 使用两个开源项目 开源侧边栏 :me.tangke.slidemenu 开源动画:nineoldandroids-2.4.0.jar 在项目里我使用的是左边activity,右边activity的样式,activityGroup的方式,如果全用Fragment也是一样的,只要获取Fragment的rootView即可; 滑动时用me.tangke.slidemenu是为获取拖动屏幕的比例,其他的菜单栏也可以使用,只是加个动画; 界面所有逻辑代码不动,使用nineoldandroids

animate.css 实现移动端垂直滑动效果

html: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <link rel="stylesheet" type="text/css" href="css/swiper.min.css"/> <link rel="stylesheet&q

原生JavaScript+CSS3实现移动端滑块效果

在做web页面时,无论PC端还是移动端,我们会遇到滑块这样的效果,可能我们往往会想着去网上找插件,其实这个效果非常的简单,插件代码的的代码往往过于臃肿,不如自己动手,自给自足.首先看一下效果图: 分析效果: 1.按钮的右侧有一个小动画,深黄色的小头是一圈圈循环流动的. 2.只在按钮上滑动可以启动按钮. 3.并且要判断按钮是否滑到头,如果没有滑到头,手指离开屏幕,按钮自动弹回左侧:如果滑到头,执行一个函数. 解决办法: 1.动画效果需要使用CSS3里面的@keyframes来操作,代码如下: 1

轻量级移动端滑动xwipe.js

工作需要写一个移动端的滑动效果,参考了swipe,和iscroll之后自己写了一个xwipe.在写的过程中学习了很多,分享一下心得. 首先html和css部分和swipe一样. html部分 xwipe结构 <div id='xwipe' class='xwipe'> <div class='xwipe-wrap'> <div></div> <div></div> <div></div> <div>