react怎么实现手机端首页无缝轮播功能
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,本篇内容主要讲解"react怎么实现手机端首页无缝轮播功能",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"react怎么实现手机端首页无缝轮播功能"吧!to
千家信息网最后更新 2025年12月03日react怎么实现手机端首页无缝轮播功能
本篇内容主要讲解"react怎么实现手机端首页无缝轮播功能",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"react怎么实现手机端首页无缝轮播功能"吧!
touchstart = this.touchStart.bind(this); touchmove = this.touchMove.bind(this); touchend = this.touchEnd.bind(this); //设置transform cssTransform(ele, attr, val){ if(!ele.transform){ ele.transform = {}; }; //当传入值时对属性进行设置。 if(arguments.length > 2){ ele.transform[attr] = val; var sval = ''; for(var s in ele.transform){ if(s === 'translateX'){ sval += s + '(' + ele.transform[s] + 'px)'; } //如果实在不理解,可以console.log(sval)可以看到到最后一张时会有一个先跳到第二张再快速到第三张的过程 ele.style.WebkitTransform = ele.style.transform = sval; } } else{ val = ele.transform[attr]; if(typeof val === 'undefined'){ if(attr === 'translateX'){ val = 0; } }; return val; } } //自动轮播 auto(){ clearInterval(this.timer); this.timer = setInterval(() => { //当到达最后一张时 if(this.now === this.props.len - 1){ this.now = this.props.len / 2 - 1; //这两句代码很重要,是实现的关键,none是为了不出现平移而是直接跳变 this.LunBoEle.style.transition = 'none'; this.cssTransform(this.LunBoEle, 'translateX', - this.now * this.sliderWidth); } //定时是为了tab函数中执行的csstransform函数与上面到达最后一张时的csstransform有先后,不然仍会导致右移; setTimeout(() => { this.now++; this.tab(); }, 30); }, this.props.delay * 1000); } tab(){ this.LunBoEle.style.transition = '.5s'; this.cssTransform(this.LunBoEle, 'translateX', -this.now * this.sliderWidth); let SelectIndex = this.now % (this.props.len / 2); $('.slider-dots-wrap span').eq(SelectIndex).addClass('slider-dot-selected').siblings().removeClass('slider-dot-selected'); } componentDidMount() { this.LunBoEle = document.querySelector('ul.lunbo'); this.SliderEle = document.querySelector('.slider'); this.sliderWidth = $('.slider').width(); this.cssTransform(this.LunBoEle, 'translateX', 0); this.auto.bind(this)(); this.SliderEle.addEventListener('touchstart', this.touchstart, false); this.SliderEle.addEventListener('touchmove', this.touchmove, false); this.SliderEle.addEventListener('touchend', this.touchend, false); }//触发 touchStart(e: TouchEvent){ e.stopPropagation(); if(!this.stopped){ clearInterval(this.timer); this.LunBoEle.style.transition = 'none'; let moveX = this.cssTransform.bind(this)(this.LunBoEle, 'translateX'); this.now = Math.round(-moveX / this.sliderWidth); if(this.now === 0){ this.now = this.props.len / 2; }else if(this.now === this.props.len - 1){ this.now = this.props.len / 2 - 1; } this.cssTransform(this.LunBoEle, 'translateX', -this.now * this.sliderWidth); this.startPoint = e.changedTouches[0].pageX; this.startEle = this.cssTransform.bind(this)(this.LunBoEle, 'translateX'); } };//移动 touchMove(e: TouchEvent){ e.preventDefault(); e.stopPropagation(); if(!this.stopped){ let endPoint = e.changedTouches[0].pageX; let disX = endPoint - this.startPoint; this.cssTransform.bind(this)(this.LunBoEle, 'translateX', disX + this.startEle); } }//平移结束 touchEnd(e: TouchEvent){ e.stopPropagation(); if(!this.stopped){ let moveX = this.cssTransform.bind(this)(this.LunBoEle, 'translateX'); //这边我是对移动做了判断 if(Math.abs(moveX) > Math.abs(this.now * this.sliderWidth)){ this.now = Math.ceil(-moveX / this.sliderWidth); }else{ this.now = Math.floor(-moveX / this.sliderWidth); } this.tab.bind(this)(); this.auto.bind(this)(); } } componentWillUnmount(){ //注意这边的清楚很重要,因为用户在使用时如果后台修改,用户刷新,会导致下面的dot出现问题 clearInterval(this.timer); //卸载的同时需要将所有事件清除掉 this.SliderEle.removeEventListener('touchstart', this.touchstart, false); this.SliderEle.removeEventListener('touchmove', this.touchmove, false); this.SliderEle.removeEventListener('touchend', this.touchend, false); } //防止如果只有一张轮播图时进行轮播 componentDidUpdate(){ if((this.props.len / 2) === 1){ clearInterval(this.timer); this.stopped = true; } else{ this.stopped = false; } } render() { let itemNodes = this.props.items.map((item, idx) => { return ; }); let dotNodes = []; let count = this.props.len / 2; for(let i = 0; i < count; i++){ //为第一个dot点加上selected dotNodes[i] = ( ); } return ( {itemNodes}
{dotNodes} 到此,相信大家对"react怎么实现手机端首页无缝轮播功能"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
功能
手机
无缝
首页
重要
内容
函数
用户
学习
平移
移动
实用
更深
清楚
事件
代码
先后
关键
兴趣
动轮
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发层面安全性要求
手机软件开发培训中心
内存数据库核心技术问题
重庆街道党性体检软件开发
登录id出现连接服务器失败
网络安全软件市场前景
中小学网络安全微课堂
长沙沙狐网络技术
数据库查询日志的作用
2003年服务器虚拟机
合肥运营网络技术哪家好
电信公司网络安全考试
计算机网络技术参考模型
武安网络技术团队
宁夏常委会贯彻网络安全
局域网邮件服务器 邮件转发
数据库原理及应用教程第二版课后答案
松下A6服务器报警16
宁夏自然资源厅网络安全培训
最强的服务器提供商
护苗 网络安全观后感
软件数据库的版本在哪里看
追溯网络安全问题
中美网络技术工作室
文件服务器动态扩容
lgg2怎么进入服务器
数据库服务器双机热备命令
荆州软件开发招生
南邮的网络安全
通州电力监控软件开发