js实现手机web图片左右滑动效果


Posted in Javascript onDecember 29, 2017

最近在做一个手机端web站点,里面有一个图片展示效果:

1、点击任意图片时图片全屏展示,左右滑动能展示其他的图片。
2、滑动超过一定范围自动滑到下一张图片,不超过则回退到当前照片位置。此处的滑动要带动画效果

实现:

每张图片外面一个div,将其宽度设置为100%,最外层有一个div[命名为outerDiv],其宽度设为:总图片数量*100+‘%'。给最外层div设置touchstart,touchmove,touchend事件监听处理函数,在touchmove中根据移动的x轴距离动态改变outerDiv的x轴距离即可实现图片滑动效果,在touchend中根据当前滑动的距离判断滑动到下一张还是回退当前图片位置。

之前我们可以通过设置outerDiv的position属性,然后改变left值实现移动效果,这里我用的是css3的动画函数transform,简单,且可以实现动画效果

transform参数:

-webkit-transform:translate(100px,200px) tr //可以设置x、y轴方向移动距离
-webkit-transform:translateX(100px) translateY(200px) translateZ(3000px) 

//可以设置x、y、z轴方向移动距离.3D效果
-webkit-transition:.4s ease;//设置动画时间

定义动画时间:

.transition {
  -webkit-transition:.4s ease;
  -moz-transition:.4s ease;
  -ms-transition:.4s ease;
  -o-transition: .4s ease;
  transition:.4s ease;
}

关键代码:

var touchOption={touchStartX:0,startTranslateX:0,moveDistance:0};

1、touchstart

outerDiv.addEventListener('touchstart',function(){
$(this).removeClass('transition');//移除动画效果,否则移动时图片会颤动
touchOption.touchStartX = e.touches[0].clientX;
        if ($(this).css("-webkit-transform") == 'none') {
          touchOption.startTranslateX = 0;
        }
        else {
          //css-webkit-transform属性值格式:matrix(1, 0, 0, 1, -4140, 0)
          var transfrom_info = $('.sourcePhotoDiv').css("-webkit-transform").split(',')[4];//获取当前outerDiv的x轴坐标
          touchOption.startTranslateX = parseInt(transfrom_info);
        }
},false);

2、touchmove

outerDiv.addEventListener('touchmove',function(){
       touchOption.moveDistance = (e.touches[0].clientX - touchOption.touchStartX);
        var TranslateX = touchOption.startTranslateX + touchOption.moveDistance;
        $(this).css('-webkit-transform', 'translateX('+ TranslateX +'px) translateZ(0)'); //移动图片
},false);

3、touchend

outerDiv.addEventListener('touchend',function(){
      $(this).addClass('transition);//添加动画效果
       var moveX=100;//此处计算移动移动下一张图片还是退货当前图片代码省略       
        $(this).css('-webkit-transform', 'translateX('+ moveX +'px) translateZ(0)'); //移动图片
},false);

总结:

1、outerDiv的动画参数和效果都是js动态添加的,不需要事先定义
2、用translate(x,y)这种参数时,图片移动时会颤动
3、用translateX() 且带translateZ(0)时图片移动正常,不带translateZ(0)同样出现颤动
4、如果用的是translateX(moveX) ranslateZ(0)这种格式,如果moveX用的是百分比值,如‘50%',在android手机自动浏览器和uc浏览器中则没有动画效果,用px单位值则正常

为防止图片移动过程颤动和保证动画效果,建议大家用translateX(100px) ranslateZ(0)这种参数,且移动距离用px值

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js本身的局限性 别让javascript做太多事
Mar 23 Javascript
jQuery源码分析-01总体架构分析
Nov 14 Javascript
浅谈Javascript面向对象编程
Nov 15 Javascript
jQuery中setTimeout的几种使用方法小结
Apr 07 Javascript
使表格的标题列可左右拉伸jquery插件封装
Nov 24 Javascript
JavaScript中的原型链prototype介绍
Dec 30 Javascript
EasyUI中datagrid在ie下reload失败解决方案
Mar 09 Javascript
js学习总结_选项卡封装(实例讲解)
Jul 13 Javascript
基于js中的原型(全面讲解)
Sep 19 Javascript
JS实现的缓冲运动效果示例
Apr 30 Javascript
解决LayUI加上form.render()下拉框和单选以及复选框不出来的问题
Sep 27 Javascript
vue data变量相互赋值后被实时同步的解决步骤
Aug 05 Javascript
详解react-router 4.0 下服务器如何配合BrowserRouter
Dec 29 #Javascript
浅谈react-router HashRouter和BrowserRouter的使用
Dec 29 #Javascript
javaScript 连接打印机,打印小票的实例
Dec 29 #Javascript
深入浅析vue组件间事件传递
Dec 29 #Javascript
详解Vue 事件修饰符capture 的使用
Dec 29 #Javascript
react-router browserHistory刷新页面404问题解决方法
Dec 29 #Javascript
node简单实现一个更改头像功能的示例
Dec 29 #Javascript
You might like
PHPWind 发帖回帖Api PHP版打包下载
2010/02/08 PHP
destoon网站转移服务器后搜索汉字出现乱码的解决方法
2014/06/21 PHP
php中getservbyport与getservbyname函数用法实例
2014/11/18 PHP
PHP使用递归生成文章树
2015/04/21 PHP
PHP Hash算法:Times33算法代码实例
2015/05/13 PHP
php实现生成验证码实例分享
2016/04/10 PHP
学习thinkphp5.0验证类使用方法
2017/11/16 PHP
php文件后缀不强制为.php的实操方法
2019/09/18 PHP
在JavaScript中使用inline函数的问题
2007/03/08 Javascript
JS之小练习代码
2008/10/12 Javascript
基于jquery的多彩百分比 动态进度条 投票效果显示效果实现代码
2011/08/28 Javascript
JavaScript去除空格的三种方法(正则/传参函数/trim)
2013/02/06 Javascript
jquery uploadify 在FF下无效的解决办法
2014/09/26 Javascript
JavaScript简单修改窗口大小的方法
2015/08/03 Javascript
详解ionic本地相册、拍照、裁剪、上传(单图完全版)
2017/10/10 Javascript
Vue源码探究之状态初始化
2018/11/14 Javascript
JS简单判断是否在微信浏览器打开的方法示例
2019/01/08 Javascript
js取小数点后两位四种方法
2019/01/18 Javascript
vue+iview实现文件上传
2020/11/17 Vue.js
Python re模块介绍
2014/11/30 Python
10分钟教你用Python实现微信自动回复功能
2018/11/28 Python
python使用wxpy轻松实现微信防撤回的方法
2019/02/21 Python
pandas修改DataFrame列名的实现方法
2019/02/22 Python
使用Filter过滤python中的日志输出的实现方法
2019/07/17 Python
纯CSS3实现圆圈动态发光特效动画的示例代码
2021/03/08 HTML / CSS
美国当红的名品折扣网:Gilt Groupe
2016/08/15 全球购物
阿根廷网上配眼镜:SmartBuyGlasses阿根廷
2016/08/19 全球购物
adidas爱尔兰官方网站:阿迪达斯运动鞋和运动服
2019/11/01 全球购物
幼师自荐信范文
2013/10/06 职场文书
护士实习生自我鉴定范文
2013/12/10 职场文书
活动邀请函范文
2014/01/19 职场文书
酒店总经理职务说明书
2014/02/26 职场文书
民事辩护词范文
2015/05/21 职场文书
Golang中interface{}转为数组的操作
2021/04/30 Golang
Windows环境下实现批量执行Sql文件
2021/10/05 SQL Server
Vue全局事件总线你了解吗
2022/02/24 Vue.js