实现抽屉侧边栏(主体移动)

效果:

代码:

html:

<div id="all">
  <div id="drawer"></div>
  <div id="main">
    <div id="nav">
      <div id="open"></div>
    </div>
    <div id="content"></div>
    <div id="mask"></div>
  </div>
</div>

css:

#all{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  background:#ddd;
  width:300px;
  height:500px;
  overflow:hidden;
}
#drawer{
  position:absolute;
  width:200px;
  height:500px;
  background:skyblue;
  top:0;
  left:-200px;
  transition:all 0.5s;
}
#main{
  position:absolute;
  width:300px;
  height:500px;
  background:tomato;
  top:0;
  left:0;
  transition:all 0.5s;
}
#nav{
  height:50px;
  background:yellow;
  position:relative;
}
#open{
  background:tomato;
  width:35px;
  height:35px;
  position:absolute;
  top:50%;
  left:10px;
  transform:translate(0,-50%);
  cursor:pointer;
}
#mask{
  display:none;
  position:absolute;
  width:300px;
  height:500px;
  top:0;
  background:rgba(0,0,0,.5);
}

javascript:

var drawer = document.getElementById("drawer");
var main = document.getElementById("main");
var mask = document.getElementById("mask");
document.getElementById("open").onclick = function(){
  drawer.style.left = 0; 
  main.style.left = 200 + "px"; 
  mask.style.display = "block";
}
mask.onclick = function(){
  drawer.style.left = -200 + "px"; 
  main.style.left = 0; 
  mask.style.display = "none";
}

原理:对元素的left属性进行动态的调整,并且在主布局中利用overflow:hidden对超出部分进行隐藏

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,690评论 1 92
  • 一:在制作一个Web应用或Web站点的过程中,你是如何考虑他的UI、安全性、高性能、SEO、可维护性以及技术因素的...
    Arno_z阅读 5,019评论 0 1
  • 转载请声明 原文链接地址 关注公众号获取更多资讯 第一部分 HTML 第一章 职业规划和前景 职业方向规划定位...
    前端进阶之旅阅读 16,720评论 32 459
  • 一个团队总有那么几个开不了单的钉子户,这些钉子户刚开始步入公司就有这种想法:销售很简单,不就是把东西卖出去吗?看似...
    尽力牛阅读 1,751评论 0 0
  • track image 哪个牌子的防晒霜比较好? 首先,每个人的肤质不同,同一种防晒霜油皮的人用起来觉得很好,干皮...
    五月桃夭阅读 1,315评论 0 0

友情链接更多精彩内容