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怎么为数据库表字段添加索引以优化查询

