侧边栏与高度适应

js侧边栏

在我新手时期,也写过许多的侧边栏,侧边栏的要求很简单,和屏幕高度保持一致,并且功能项能在内部进行滚动,当时的我也是煞费苦心,为了能够准确地自适应,不得不用js去进行实现

$(window).resize(function(){
    let sidebar = $('#dashboard-sidebar');
    sidebar.css('height', 'auto');
    let h = Math.max(sidebar.outerHeight(), $(window).height() - $('#header').height());
    sidebar.css('height', h);
}).resize();

可以说是非常的愚蠢了,每次都要在窗口变动的时候重新计算,会有视觉上的延误。

并且在首屏加载完成之前,还要忍受一个不正常的侧边栏等待渲染。

绝对定位侧边栏

在后续的开发中,觉得js实现侧边栏实在是太过愚蠢,不停地寻找解决方案的时候,发现实际上绝对定位是可以为我们解决问题的。

给侧边栏定好宽度,然后进行绝对定位,css会自动帮我们将高度和屏幕自适应,在很长一段时间内为我解决了问题。

position: fixed;
top: 0;
bottom: 0;
left: 0;
background-color: #444F61;
overflow-y: auto;

很简单就完成了一个自适应的侧边栏,唯一的缺点就是因为使用了绝对定位,其他的元素得注意是否要纷纷绕道。

现在的侧边栏

后来由于绝对定位也是为我带来了一定程度上的困扰,一旦我修改侧边栏,其他元素也要纷纷跟着移动,每次修改起来也是令人很头疼,所以又开始研究其他的解决方案。

后来在使用bootstrap的时候,也沿用了它所使用的一个css属性值 vh。

很担心兼容性的我去MDN上进行了一下兼容性的查询,IE9就已经支持了。另外如果侧边栏之上还有顶部导航栏,仍然可以使用计算属性:

height: 100vh;
height: calc(100vh - 60px);

除了vh以外,也有很多类似的属性值如:vw、 vmin 和 vmax,都是进行自适应开发不错的选择。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
侧边栏收缩时,echarts饼图没有自适应的情况下,可以采取以下方法解决。首先,监听侧边栏的收缩事件,在侧边栏收缩时触发相应的事件。其次,通过获取饼图的容器元素,并根据容器元素的大小变化重新设置echarts实例的宽度和高度。最后,调用echarts实例的resize方法,使饼图适应新的容器尺寸。通过这种方式,可以实现echarts饼图在侧边栏收缩时的自适应效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [echarts宽高自适应](https://blog.csdn.net/qq_41818857/article/details/117996235)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue Echarts 自适应问题](https://blog.csdn.net/jj_0628/article/details/102968416)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [echarts饼图各个板块之间的空隙如何实现](https://download.csdn.net/download/weixin_38708841/14919497)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值