js实现移动端导航点击自动滑动效果

发布时间 - 2026-01-11 02:23:55    点击率:

本文实例为大家分享了js实现移动端导航点击滑动效果的具体代码,供大家参考,具体内容如下

移动端模拟导航可点击自动滑动 0.1.4。

导航可左右滑动,可点击边缘的一个,自动滚动下一个到可视范围【依赖于iscroll.js】。

废话不多说直接上代码:

/* 
 * 移动端模拟导航可点击自动滑动 0.1.4 
 * Date: 2017-01-11 
 * by: xiewei 
 * 导航可左右滑动,可点击边缘的一个,自动滚动下一个到可视范围【依赖于iscroll.js】 
 */ 
(function ($) { 
 $.fn.navbarscroll = function (options) { 
 //各种属性、参数 
 var _defaults = { 
 className:'cur', //当前选中点击元素的class类名 
 clickScrollTime:300, //点击后滑动时间 
 duibiScreenWidth:0.4, //单位以rem为准,默认为0.4rem 
 scrollerWidth:3, //单位以px为准,默认为3,[仅用于特殊情况:外层宽度因为小数点造成的不精准情况] 
 defaultSelect:0, //初始选中第n个,默认第0个 
 fingerClick:0, //目标第0或1个选项触发,必须每一项长度一致,方可用此项 
 endClickScroll:function(thisObj){}//回调函数 
 } 
 var _opt = $.extend(_defaults, options); 
 this.each(function () { 
 //插件实现代码 
 var _wrapper = $(this); 
 var _win = $(window); 
 var _win_width = _win.width(),_wrapper_width = _wrapper.width(),_wrapper_off_left = _wrapper.offset().left; 
 var _wrapper_off_right=_win_width-_wrapper_off_left-_wrapper_width; 
 var _obj_scroller = _wrapper.children('.scroller'); 
 var _obj_ul = _obj_scroller.children('ul'); 
 var _obj_li = _obj_ul.children('li'); 
 var _scroller_w = 0; 
 _obj_li.css({"margin-left":"0","margin-right":"0"}); 
 for (var i = 0; i < _obj_li.length; i++) { 
 _scroller_w += _obj_li[i].offsetWidth; 
 } 
 _obj_scroller.width(_scroller_w+_opt.scrollerWidth); 
 var myScroll = new IScroll('#'+_wrapper.attr('id'), { 
 eventPassthrough: true, 
 scrollX: true, 
 scrollY: false, 
 preventDefault: false 
 }); 
 _init(_obj_li.eq(_opt.defaultSelect)); 
 _obj_li.click(function(){ 
 _init($(this)); 
 }); 
 //解决PC端谷歌浏览器模拟的手机屏幕出现莫名的卡顿现象,滑动时禁止默认事件(2017-01-11) 
 _wrapper[0].addEventListener('touchmove',function (e){e.preventDefault();},false); 
 function _init(thiObj){ 
 var $this_obj=thiObj; 
 var duibi=_opt.duibiScreenWidth*_win_width/10,this_index=$this_obj.index(),this_off_left=$this_obj.offset().left,this_pos_left=$this_obj.position().left,this_width=$this_obj.width(),this_prev_width=$this_obj.prev('li').width(),this_next_width=$this_obj.next('li').width(); 
 var this_off_right=_win_width-this_off_left-this_width; 
 if(_scroller_w+2>_wrapper_width){ 
  if(_opt.fingerClick==1){ 
  if(this_index==1){ 
  myScroll.scrollTo(-this_pos_left+this_prev_width,0, _opt.clickScrollTime); 
  }else if(this_index==0){ 
  myScroll.scrollTo(-this_pos_left,0, _opt.clickScrollTime); 
  }else if(this_index==_obj_li.length-2){ 
  myScroll.scrollBy(this_off_right-_wrapper_off_right-this_width,0, _opt.clickScrollTime); 
  }else if(this_index==_obj_li.length-1){ 
  myScroll.scrollBy(this_off_right-_wrapper_off_right,0, _opt.clickScrollTime); 
  }else{ 
  if(this_off_left-_wrapper_off_left-(this_width*_opt.fingerClick)<duibi){ 
  myScroll.scrollTo(-this_pos_left+this_prev_width+(this_width*_opt.fingerClick),0, _opt.clickScrollTime); 
  }else if(this_off_right-_wrapper_off_right-(this_width*_opt.fingerClick)<duibi){ 
  myScroll.scrollBy(this_off_right-this_next_width-_wrapper_off_right-(this_width*_opt.fingerClick),0, _opt.clickScrollTime); 
  } 
  } 
  }else{ 
  if(this_index==1){ 
  myScroll.scrollTo(-this_pos_left+this_prev_width,0, _opt.clickScrollTime); 
  }else if(this_index==_obj_li.length-1){ 
  if(this_off_right-_wrapper_off_right>1||this_off_right-_wrapper_off_right<-1){ 
  myScroll.scrollBy(this_off_right-_wrapper_off_right,0, _opt.clickScrollTime); 
  } 
  }else{ 
  if(this_off_left-_wrapper_off_left<duibi){ 
  myScroll.scrollTo(-this_pos_left+this_prev_width,0, _opt.clickScrollTime); 
  }else if(this_off_right-_wrapper_off_right<duibi){ 
  myScroll.scrollBy(this_off_right-this_next_width-_wrapper_off_right,0, _opt.clickScrollTime); 
  } 
  } 
  } 
 } 
 $this_obj.addClass(_opt.className).siblings('li').removeClass(_opt.className); 
 _opt.endClickScroll.call(this,$this_obj); 
 } 
 }); 
 }; 
})(jQuery);

截图:

提供demo地址:

更多关于滑动效果的专题,请点击下方链接查看:

javascript滑动操作汇总

jquery滑动操作汇总

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


# js移动端滑动  # iscroll.js点击自动滑动  # js导航点击滑动  # JS中用三种方式实现导航菜单中的二级下拉菜单  # JS实现选中当前菜单后高亮显示的导航条效果  # 一个js控制的导航菜单实例代码  # CSS3+Js实现响应式导航条  # JS 实现导航栏悬停效果  # JavaScript实现鼠标点击导航栏变色特效  # js实现无限级树形导航列表效果代码  # js实现的常用的左侧导航效果  # JavaScript实现滑动导航栏效果  # 原生js实现波浪导航效果  # 默认为  # 边缘  # 请点击  # 依赖于  # 多说  # 此项  # 大家分享  # 更多关于  # 回调  # 具体内容  # 大家多多  # 每一项  # fingerClick  # defaultSelect  # thisObj  # endClickScroll  # text  # rem  # duibiScreenWidth  # px 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: java中使用zxing批量生成二维码立牌  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  用v-html解决Vue.js渲染中html标签不被解析的问题  javascript日期怎么处理_如何格式化输出  C#如何调用原生C++ COM对象详解  html如何与html链接_实现多个HTML页面互相链接【互相】  微信小程序 wx.uploadFile无法上传解决办法  Laravel如何集成Inertia.js与Vue/React?(安装配置)  html5的keygen标签为什么废弃_替代方案说明【解答】  Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道  大学网站设计制作软件有哪些,如何将网站制作成自己app?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  如何快速搭建安全的FTP站点?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  ,在苏州找工作,上哪个网站比较好?  android nfc常用标签读取总结  音响网站制作视频教程,隆霸音响官方网站?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  微信小程序 canvas开发实例及注意事项  javascript如何操作浏览器历史记录_怎样实现无刷新导航  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  移动端脚本框架Hammer.js  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  JavaScript Ajax实现异步通信  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  如何在景安云服务器上绑定域名并配置虚拟主机?  如何快速搭建虚拟主机网站?新手必看指南  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  Laravel集合Collection怎么用_Laravel集合常用函数详解  Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)  如何打造高效商业网站?建站目的决定转化率  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  Android okhttputils现在进度显示实例代码  如何在 Pandas 中基于一列条件计算另一列的分组均值  创业网站制作流程,创业网站可靠吗?  轻松掌握MySQL函数中的last_insert_id()  如何在云主机上快速搭建多站点网站?  微信小程序 五星评分(包括半颗星评分)实例代码  zabbix利用python脚本发送报警邮件的方法  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  Laravel怎么为数据库表字段添加索引以优化查询