vue+elementUi 点击图片跳后,页面滚动条消失了

在使用Vue和低版本ElementUi时,发现一个bug:点击el-image组件跳转后,页面滚动条消失且body添加了overflow:hidden。原因是ElementUi的一个已知问题。解决方案包括升级ElementUi到2.13.1以上版本或在路由后置守卫中手动设置body的overflow属性为auto。

vue+elementUi 点击图片跳后,页面滚动条消失了

使用el-image跳转到新页面后,页面的滚动条消失了,并且HTML的body被加上了overflow:hidden属性。在项目中没有找到相应的属性添加代码,百度才发现是elementUi的bug。项目比较老旧,element-ui的版本较低,所以存在这个问题。

在这里插入图片描述

结构代码
<el-card
 v-for="(item,index) in imageList"
 :key="item.id">
     <div slot="header">
         <router-link :to="item.path">
        	 <el-image :src="item.url" lazy>
         </router-link>
     </div>
 </el-card>
解决办法

1.将element-ui更新至2.13.1版本,该版本官方修复了这个bug。

2.给body设置属性

// 通过路由设置
router.afterEach((to, from, next) => {
  document.querySelector("body").setAttribute("style", "overflow: auto !important;")
});
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值