VUE+ElementUI dialog打开时禁止iOS端的body滚动

 

现象:

在原生app中嵌套web页面时,时常会遇到由于系统不同带来的差异。

此次引入ElementUI,使用其中的dialog组件时,明明默认dialog显示时,body不能滚动:

element UI 文档

安卓和pc下没毛病,但在iOS下lock-scroll无效,dialog背后的body依然可以滚动。

 

 

解决方法:

思路:

      主要是在打开dialog时设置html的

      position:fixed;

      scroll:no;

      overflow:hidden;(以防万一,加上)

 

      dialog关闭时:

      position:relative;

      scroll:yes;

      overflow:scroll;

实践:

1.添加lock和unlock方法(这里是加在了公共方法util.js里,以便各个组件都可以使用,也可以直接写在各个component的method里):

function lock() {

  document.documentElement.style.overflow = "hidden";

  document.documentElement.style.position = "fixed";

  document.body.scroll = "no"; 

}



function unLock() {

  document.documentElement.style.overflow = "scroll";

  document.documentElement.style.position = "relative";

  document.body.scroll = "yes";

}

2.在组件中引入js,watch监听dialog显示的参数,当dialog显示时调用lock方法,dialog隐藏时调用unlock方法:

<el-dialog

        title="test dialog"

        :visible.sync="centerDialogVisible"

      >

        <div class="testBox">

          Test

        </div>

      </el-dialog>



import util from "../util";

 watch: {

    centerDialogVisible(val) {

      if (val === true) {

        util.lock();

      } else {

        util.unLock();

      }

    }

}


  

问题发生原因:

主要是overflow:hidden在iOS下会失效,而查看ElementUI源码可以看到,lockscroll参数做的事,主要就是给body的overflow加hidden值。

lock-scroll参数指向的js方法

js添加的class的样式

最后:

如果有更棒的解决方法,欢迎指教!

 

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值