slideout

Posted 最爱小虾

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了slideout相关的知识,希望对你有一定的参考价值。

这里在原有slideout.js增加了shade的遮罩功能

核心:

1,此插件的使用需要配合dom来用;

<!-- 左边 -->
<nav id="menu" class="menu">
  <a href="#" target="_blank">
    <header class="menu-header">
      <span class="menu-header-title">个人中心</span>
    </header>
  </a>
  <section class="menu-section">
    <h3 class="menu-section-title">姓名</h3>
    <ul class="menu-section-list">
      <li><a href="#" target="_blank">我的订单</a></li>
      <li><a href="#" target="_blank">我的地址</a></li>
      <li><a href="#" target="_blank">设置</a></li>
      <li><a href="#" target="_blank">退出</a></li>
    </ul>
  </section>
</nav>

<!-- 右边 -->
<main id="main" class="panel">
    <!-- 遮罩 -->
    <div class="shade" id="shade"></div>
    <!-- 按钮 -->
    <button class="btn-hamburger js-slideout-toggle"></button>
</main>

 

2,使用环境中,判断用户的登录状态;

3,源码中修改的地方 注意close(),与open()事件;

完整源码:

<!doctype html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> 
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>移动手机的侧边栏滑动</title>
<link rel="stylesheet" href="slideout.css">
<link rel="stylesheet" href="common.css">
</head>
<body>
<!-- 左边 -->
<nav id="menu" class="menu">
  <a href="#" target="_blank">
    <header class="menu-header">
      <span class="menu-header-title">个人中心</span>
    </header>
  </a>
  <section class="menu-section">
    <h3 class="menu-section-title">姓名</h3>
    <ul class="menu-section-list">
      <li><a href="#" target="_blank">我的订单</a></li>
      <li><a href="#" target="_blank">我的地址</a></li>
      <li><a href="#" target="_blank">设置</a></li>
      <li><a href="#" target="_blank">退出</a></li>
    </ul>
  </section>
</nav>
<!-- 右边 -->
<main id="main" class="panel">
    <!-- 遮罩 -->
    <div class="shade" id="shade"></div>
    <article>
        <ul class="header flex flex-row flex-align-center">
            <li style="margin-right:20px;width:26px;">
                <button class="btn-hamburger" id="toggle-btn"></button>
            </li>
            <li class="flex-1 header-title">
                名称
            </li>
            <li style="width:22px;padding:5px 15px;">
                <img class="listtype" src="https://s1.ax1x.com/2017/12/13/bjnyj.png" alt="">
            </li>
        </ul>
    </article>
</main>
<script type="text/javascript" src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script>
<script type="text/javascript" src="slideout.js"></script>
<script type="text/javascript">
    var flag = 1 //;是否登录;1:登录,0:未登录
    if(flag == 1){
        $("#toggle-btn").addClass("js-slideout-toggle")
        if($("#toggle-btn").hasClass("js-slideout-toggle")){
        // 左边菜单滑动-start
            var slideout = new Slideout({
                panel: document.getElementById(main),
                menu: document.getElementById(menu),
                padding: 256,
                tolerance: 70
            });
            document.querySelector(.js-slideout-toggle).addEventListener(click, function() {
                slideout.toggle();
            });
            // 点击遮罩,收回侧边栏
            document.querySelector(.shade).addEventListener(click, function() {
                slideout.toggle();
            });
            document.querySelector(.menu).addEventListener(click, function(eve) {
                if (eve.target.nodeName === A) { slideout.close(); }
            });
        // 左边菜单滑动-end
        }
    }else{
        $("#toggle-btn").removeClass("js-slideout-toggle");
        $("#toggle-btn").click(function () {
            alert("请登录");
        })
    }
</script>
</body>
</html>

 

预览地址:

https://besswang.github.io/slideout-test/index.html

以上是关于slideout的主要内容,如果未能解决你的问题,请参考以下文章

html Slideout.js

微信小程序代码片段

VSCode自定义代码片段——CSS选择器

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

片段和活动之间的核心区别是啥?哪些代码可以写成片段?

VSCode自定义代码片段——.vue文件的模板