您好,登录后才能下订单哦!
本篇文章给大家分享的是有关利用JavaScript怎么实现一个页面侧边栏效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
/** css代码 */ width: 50px; height: 50px; background-color: red; display: none; transform: translateX(0); transition: all .6s ease; //似乎没用?
//js代码 ds.style.display="block"; ds.style.transform="translateX(100px)";
但是同样的,当对以下属性进行操作的时候,由于浏览器的渲染机制有一些API可以使页面强制渲染(因为要获得详细确切的信息),包括:offsetTop、offsetLeft、 offsetWidth、offsetHeight、scrollTop、scrollLeft、scrollWidth、scrollHeight、clientTop、clientLeft、clientWidth、clientHeight、getComputedStyle() (currentStyle in IE)。这会直接导致前后两行相当于“渲染了两遍”。
所以将上方js代码改为下面这样:
//js代码 ds.style.display="block"; ds.offsetHeight; ds.style.transform="translateX(100px)";
目前csdn官网PC端blink发布页面的图片上传就用了类似这个功能!
后来还是觉得这种方式需要涉及js对页面结构的改变,于是乎…
这基于position定位是会“重合”的:在两个行内元素都设置了定位属性(但没有加top/left/bottom/right定位)后,后面的会覆盖前面的;这时候可以通过margin移动位置展示。
只能是行内元素,行内块元素都不行。 ——云小梦
它大概结构是这样的:
<div class="page_list"> <div class="z_two_page"> <!-- 这里放右侧弹框展示的信息 --> </div> <div class="box"> <!-- "页面"的遮罩层 --> <div class="zb_mask"></div> <!-- 这里放“页面”数据结构(也就是原本应该在body标签下的所有东西) --> </div> <!-- 这是占位元素 --> <div class="space"></div> </div>
实际就像这样的:
<div class="page_list"> <div class="z_two_page">哈哈哈</div> <div class="box"> <div class="zb_mask"></div> <div id="boxs"> <div class="left" ></div> <div class="right" > flex下两列布局左边固定右边宽高自适应 </div> </div> <div class="color"></div> <a href="#" rel="external nofollow" class="a">千万小心像对a设置全局样式(这叫啥样式重置)</a> <div class="center"> <div class="ds"></div> <button class="but">到指定地点</button> </div> <form id="form" action="#"> <input type="submit" value="="踢脚板 /> </form> <img id="img" src="compress/compress/img/mxc_16x16.png" /> </div> <div class="space"></div> </div>
如上,class为“box”的div里面放的就是“原本的页面整体”部分。为了达到想要的效果,我们采用了flex布局!
flex简写时包括三个属性:flex-grow、flex-shrink和flex-basis ——
flex-grow:指定了容器剩余空间多余时候的分配规则,默认值是0,多余空间不分配;
flex-shrink:指定了容器剩余空间不足时候的分配规则,默认值是1,空间不足要分配;
flex-basis:flex-basis则是指定了固定的分配数量,默认值是auto。
设置的同时需设置width或者height属性;
/* 列表仅水平滚动 */ .page_list { width: 100vw; display: flex; overflow-y: hidden; } /* 主内容宽度100%,白色背景覆盖 */ .box { flex: 0 0 100vw; height: 100%; background-color: #fff; position: relative; overflow-y: auto;overflow-x: hidden;transition: all .6s ease; } /** 遮罩层样式 */ .zb_mask{ position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 100; background-color: rgba(0,0,0,.2); pointer-events: none; opacity: 0; transition: all .6s ease; } /* 空标签元素,作用是腾出水平滚动空间 */ .space { flex: 0 0 12rem; } /* 按钮固定定位,藏在内容白色背景后面 */ .z_two_page { width: 12rem; position: fixed; right: 0; top: 0; }
大概就是:什么也不干的情况下只展示box的内容(也就是和不加这些花里胡哨的div一样的效果),它是用background
覆盖后面的class
为“space”的占位元素;在”哈哈哈“展示的时候,box右移。
这里需要注意的是:为什么“哈哈哈”所属div在前而“页面”所属div在后?
因为根据前面所说,这里采用的是position覆盖,它的规则就是“后面的覆盖前面的”,所以如果采用这种布局方式,那么一开始被隐藏的元素就要放在前面。
代码中flex的前两个属性值为0,表示在空间增大或缩小时依然保持原状(这是本文的基础!),第三个元素则写了展示时的“默认大小”:如你所看,box承载的是页面,所以它是100vw
,而class
为“z_two_page”的元素这里设置了12rem
,你完全可以将这个值换掉!
那如何将“哈哈哈”展示在视野中? —— js控制“代表页面的元素”整体移动即可。
这里有个“遮罩层效果”,按照传统的js实现肯定就要去找display了,再进一步可以用上面所说的“display动画效果”增强体验。
但是本文上面css代码中加了 pointer-events
属性:元素是否穿透;设置为none时就可以不用在意对应元素是否存在了(从事件上看此时有和没有一样了),也就不用控制display什么的,大大增强性能了有木有!
let right=document.querySelector(".right"); let box=document.querySelector(".box"); let mask=document.querySelector(".zb_mask"); right.onclick=function(){ box.style.marginLeft="-12rem"; mask.style.cssText+="opacity: 1;pointer-events: all;" } mask.onclick=function(){ box.style.marginLeft="0"; mask.style.cssText+="opacity: 0;pointer-events: none;" }
最后,考虑到移动端页面展示的一些问题,比如:右侧留白问题、原生手势对页面整体的影响等,我们一般会在css中设置 html{max-width: 100vw;overflow-x: hidden;}
。如果你想要用户在移动端依然只能够通过点击弹出侧边栏,在这里我们可以在css中加上限制 —— 设置上方功能只有在PC端生效:
@media (any-hover: none) { .page_list{ overflow-x: hidden; } }
以上就是利用JavaScript怎么实现一个页面侧边栏效果,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。