移动端左右滑动导航

 

移动端左右滑动导航

移动端项目中,当导航栏目多的时候,需要左右滑动,且隐藏横向滚动条

纯css即可实现此效果

 

<div class="menu-outer">
<ul class="menu">
<li><a href="javascript:void(0);">15天预报</a></li>
<li><a href="javascript:void(0);">逐小时预报</a></li>
<li><a href="javascript:void(0);">长期预报</a></li>
<li><a href="javascript:void(0);">当前天气</a></li>
<li><a href="javascript:void(0);">AQI预报</a></li>
<li><a href="javascript:void(0);">AQI逐小时</a></li>
<li><a href="javascript:void(0);">AQI城市排名</a></li>
<li><a href="javascript:void(0);">天气指数</a></li>
<li><a href="javascript:void(0);">台风路径</a></li>
<li><a href="javascript:void(0);">天气要闻</a></li>
</ul>
</div>

-------------------------------------------------

/*各个部分样式*/
@charset "utf-8";
.menu-outer{
height: 1.8rem;
overflow: hidden;//父元素设置固定高度,小于子元素高度,超出隐藏滚动条

}
.menu{
width: 100%;
overflow: auto;
margin: 0 auto;
height: 120%;//子元素ul的高度超出父元素,由于父元素设置hidden,则隐藏了滚动时候的横向滚动条了
white-space: nowrap;
}
.menu>li{
width: auto;
display: inline-block;
margin: 0 0.3rem;
}
.menu>li>a{
color: #000;
font-size: 0.85rem;
}

=============================

 参考链接下载地址:https://files.cnblogs.com/files/leshao/%E7%A7%BB%E5%8A%A8%E7%AB%AF%E5%AF%BC%E8%88%AA.rar

===========20181117更新============

如果需要点击当前,当前聚焦显示下划线,则使用下面的版本

 

 

------------------

参考下载链接地址:https://files.cnblogs.com/files/leshao/%E6%A8%AA%E5%90%91%E5%AF%BC%E8%88%AA%E4%B8%8B%E5%88%92%E7%BA%BF.rar

 ======================2018.11.08日更新============================

这个时候,使用上面的demo来开发项目

项目中,设置了html{overflow-flow:hidden;}

导致上面demo不可以使用,新开发一个版本

 

 

 

------------------------------------

<!--container一级导航-->
<div class="container">
  <nav class="nav">
    <p class="con">
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
      <a href="javascript:void(0);">导航菜单</a>
    <a href="javascript:void(0);">导航菜单</a>
  </p>
  </nav>
</div>
<!--container一级导航-->

---------------------------------------

/*各个部分样式*/
@charset "utf-8";

html {
overflow-x: hidden;
}

.container {
height: 1rem;
-webkit-box-sizing: border-box;
box-sizing: border-box;
overflow: hidden;
}

.nav {
height: 100%;
overflow-x: scroll;
overflow-y: hidden;
/*解决ios上滑动不流畅*/
-webkit-overflow-scrolling: touch;
}

.con {
width: 219%;
height: 100%;
display: flex;
display: -webkit-flex;
align-items: center;
-webkit-align-items: center;
border-bottom: 2px #ccc solid;
}

.con>a {
text-align: center;
width: auto;
color: #000;
display: inline-block;
margin: 0 0.12rem;
font-size: 0.32rem;
line-height: 0.99rem;
height: 0.99rem;
}

.con>a.active {
border-bottom: 2px rgb(255, 123, 0) solid;
color: rgb(255, 123, 0);
}


.container ::-webkit-scrollbar {
display: none;
}

----------------------------------------------

<script type="text/javascript">
$(document).ready(function() {
$(".con").find("a:first-child").addClass("active");
$(".con>a").each(function(i) {
$(this).click(function() {
$(this).addClass("active").siblings().removeClass("active");
});
});
});
</script>

==========================================

 下载地址:https://files.cnblogs.com/files/leshao/%E7%9B%92%E6%A8%A1%E5%9E%8B%E5%AE%9E%E7%8E%B0%E5%AF%BC%E8%88%AA.rar

此模板参考链接:https://www.jianshu.com/p/f282b1cc24fb

 

======================20181109继续更新==============================

项目中使用的是jsp开发的,导航作为一个单独的nav.jsp来使用,需要的页面include进去

导航跳转页面,通过a href来实现

现在要实现,点击菜单,跳转页面之后,当前菜单聚焦高亮 显示 

 

 

 

=====================================

<div class="container">
  <nav class="nav">
    <p class="con">
      <a href="a.html?currentIndex=0">00000</a>
      <a href="b.html?currentIndex=1">11111</a>
      <a href="c.html?currentIndex=2">22222</a>
      <a href="d.html?currentIndex=3">33333</a>
      <a href="e.html?currentIndex=4">44444</a>
      <a href="f.html?currentIndex=5">55555</a>
      <a href="j.html?currentIndex=6">66666</a>
      <a href="h.html?currentIndex=7">77777</a>
      <a href="i.html?currentIndex=8">88888</a>
      <a href="k.html?currentIndex=9">99999</a>
    </p>
  </nav>
</div>

---------------------------------------------------------

<script type="text/javascript">
function getUrlParam(paramName) {
//var params = location.href.substr(1).split('&');
var params = location.search.substr(1).split('&');
var result = null;
for (var i = 0; i < params.length; i++) {
var aParam = params[i].split('=');
if (aParam[0] == paramName) {
result = aParam[1];
break;
}
}
return result
}

$(document).ready(function() {
var currentIndex = 0;
currentIndex = getUrlParam('currentIndex')
$(".con a").eq(currentIndex).addClass("active");
$(".con a").click(function(i) {
$(this).addClass("active").siblings().removeClass("active");
});
});
</script>

=======================

下载地址:https://files.cnblogs.com/files/leshao/%E7%82%B9%E5%87%BB%E8%B7%B3%E8%BD%AC%E9%A1%B5%E9%9D%A2%E8%81%9A%E7%84%A6.rar

 =============================================================================================================

---------------------------------------------------------------------20181112更新-----------------------------------------------------------------------

继续上个问题,进阶。

要实现:移动端导航,左右滑动,且通过a标签跳转链接页面,且聚焦的导航,点击跳转之后,高亮显示,在可视区域。

 

 

 ----------------------------

结构 样式都同步上次的

现在修改了下jq

思路:获取一下高亮的选项宽度+它距左边的距离-屏幕的宽度的,得出来的值就是向左滚动的距离
下面代码里面的:addedValue可以自己随便定值。方便显示出下一个菜单
跳转的话,就是默认执行curItem这个函数。告诉它当前高亮的index值
---------------------------------------

$(document).ready(function() {
curItem(getUrlParam("currentIndex"))

});

function curItem(index) {
if(index === -1) {
return
}

var curDOM = $(".con a").eq(index), // 当前的a DOM元素
viewDOM = $(".nav"), // 视图 DOM元素
viewWidth = viewDOM.width(), // 视图宽度
leftRange = curDOM.offset().left, // 当前的a DOM元素距离视图DOM最左边的距离
addedValue = 100; // 附加值,自己定义。主要为了在滚动后,显示出后面的菜单

if(leftRange + curDOM.width() + addedValue > viewWidth) {
// 如果当前的 A DOM元素距离左边的距离,大于视图宽度,说明是看不到的状态
viewDOM.scrollLeft(viewDOM.scrollLeft() + (leftRange + curDOM.width() - viewWidth + addedValue))
} else if(leftRange - curDOM.width() < viewDOM.scrollLeft()) {
// 如果当前的 A DOM元素距离左边的距离,小于视图scrollLeft的值,说明是看不到的状态
viewDOM.scrollLeft(viewDOM.scrollLeft() + leftRange - addedValue)
}

curDOM.addClass("active").siblings().removeClass("active");
}

----------------------------------------------

下载链接地址:https://files.cnblogs.com/files/leshao/%E7%A7%BB%E5%8A%A8%E7%AB%AF%E5%AF%BC%E8%88%AA%E8%B7%B3%E8%BD%AC%E8%81%9A%E7%84%A6%E6%BB%91%E5%8A%A8.rar

感谢 华仔  得以完善,哈

 

posted @ 2018-11-06 19:14  乐少007  阅读(6353)  评论(0编辑  收藏  举报