欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue解決彈出蒙層滑動穿透問題的方法

 更新時間:2018年09月22日 11:45:05   作者:布爾-  
這篇文章主要介紹了vue解決彈出蒙層滑動穿透問題的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

最近開發(fā)過程中遇到一些小問題(似乎問題總是那么多),但一直沒什么時間去優(yōu)化與解決。程序員不能被業(yè)務綁架,有時間還是花點在代碼上😀,開始這次的vue嘗試吧。

【遇到的問題】

在一個可滑動列表頁彈出一個全屏蒙層,蒙層固定,中間一塊顯示消息框,當用手滑動蒙層空白處時,滑動事件會穿透到底部列表頁,導致列表頁的滑動。

【要實現(xiàn)的目標】

1. 滑動蒙層空白處不讓滑動事件穿透?! ?/p>

2. 當蒙層消息框文字多時,要讓文字可上下滑動。

要實現(xiàn)的效果其實如下:

【實現(xiàn)思路】

1. vue提供的@touchmove.prevent可以用來阻止滑動,但是這個方法會對其內(nèi)的子div的滑動事件也禁止掉了,這樣會導致中間文字無法滑動。如果沒有中間滑動需求,用@touchmove.prevent實現(xiàn)是一個很好的方法。

2. 蒙層設為fixed懸浮在最上,底部列表設置overflow-y: hidden;這樣可以列表內(nèi)容就不可以滑了,但實際過程中沒有效果,于是想到繼續(xù)往列表父div向上追溯,對body和html標簽設置相關樣式,這樣就控制住了底部列表滑動問題。

3. 蒙層空白處點擊事件與中間文字點擊事件處理,防止事件冒泡帶來其他bug。

【相關實現(xiàn)代碼】

1. html代碼都是比較簡單,列表頁for循環(huán)實現(xiàn);蒙層用一個變量控制其顯示和隱藏。但這里有幾個注意點: a. 給上面列表的div動態(tài)綁定了noScroll class,它的作用是當消息蒙層顯示時切換到相關的css樣式; b. 彈出的全屏蒙層,加有點擊事件是為了點空白處讓蒙層消失,但這里對顯示的每行文字還加了@click.stop="messageTitleClick(num)"這個方法,為什么加它呢——是因為蒙層空白處的點擊方法對整個蒙層都生效,在文字上加上這個方法可以屏蔽掉蒙層點擊方法的影響,即使這個方法里什么也不做它也是有作用的,另外這個方法上加了stop是為了防止它的點擊事件穿透到后面的div。代碼如下:

<!-- 列表 -->
 <div :class="{noScroll: isShowPopup}">
  <div class="item" v-for="num in 50" @click="itemClick(num)">
  <div style="width:100%">點擊item{{num}}</div>
  </div>
 </div>

   <!-- 蒙層 -->
 <div v-if="isShowPopup" class="popup" @click="popUpEmptyClick()">
  <div class="message">
  <p class="message-title" v-for="num in 30" @click.stop="messageTitleClick(num)">
   消息提示 {{num}}
  </p>
  </div>
 </div>

2. 給整個列表動態(tài)綁定的css如下

/* 當前蒙層顯示時生效 */
.noScroll {
 overflow-y: hidden;
}

3. 給列表整個div動態(tài)綁定.noScroll 后,底部列表照樣可以滑動,所以考慮繼續(xù)向上追溯。利用watch監(jiān)聽蒙層是否顯示,當顯示時,設置body相應樣式;但蒙層消失時,body樣式恢復。但是在vue里怎么操作body里,雖然vue是數(shù)據(jù)驅(qū)動的,不提倡直接操作Dom。但此刻我也是沒什么好辦法了,就直接操作Dom了。如下:

watch: {
 isShowPopup(newVal, oldVal) {
  if (newVal == true) {
  let cssStr = "overflow-y: hidden; height: 100%;";
  document.getElementsByTagName('html')[0].style.cssText = cssStr;
  document.body.style.cssText = cssStr;
  } else {
  let cssStr = "overflow-y: auto; height: auto;";
  document.getElementsByTagName('html')[0].style.cssText = cssStr;
  document.body.style.cssText = cssStr;
  }

  // 下面需要這兩行代碼,兼容不同瀏覽器
  document.body.scrollTop = this.pageScrollYoffset;
  window.scroll(0, this.pageScrollYoffset);
 }
 }

【補充】

最好去查看完整的demo代碼,因為后續(xù)代碼對真機上一些滑動問題進行了修復補充,包括處理一些滾動條位置等。

【Demo地址】

手動將路由切到 /three 就是此頁示例

https://github.com/LiJinShi/wechat_back_vue

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • VUE響應式原理的實現(xiàn)詳解

    VUE響應式原理的實現(xiàn)詳解

    這篇文章主要為大家詳細介紹了VUE響應式原理的實現(xiàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • 教你用Cordova打包Vue項目的方法

    教你用Cordova打包Vue項目的方法

    這篇文章主要介紹了教你用Cordova打包Vue項目的方法,詳細的介紹了如何Vue項目打包成app,具有一定的參考價值,有興趣的可以了解一下
    2017-10-10
  • Vue + OpenLayers 快速入門學習教程

    Vue + OpenLayers 快速入門學習教程

    大家都知道使用 Openlayers可以很靈活自由的做出各種地圖和空間數(shù)據(jù)的展示。而且這個框架是完全免費和開源的,本文記錄下 Vue 使用 OpenLayers 入門,使用 OpenLayers 創(chuàng)建地圖組件的相關知識,需要的朋友一起學習下吧
    2021-09-09
  • Vue組件上使用v-model之單選框

    Vue組件上使用v-model之單選框

    這篇文章主要介紹了Vue組件上使用v-model之單選框,代碼分為子組件內(nèi)容和父組件內(nèi)容,本文結合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • Vue 401配合Vuex防止多次彈框的案例

    Vue 401配合Vuex防止多次彈框的案例

    這篇文章主要介紹了Vue 401配合Vuex防止多次彈框的案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 對vuejs的v-for遍歷、v-bind動態(tài)改變值、v-if進行判斷的實例講解

    對vuejs的v-for遍歷、v-bind動態(tài)改變值、v-if進行判斷的實例講解

    今天小編就為大家分享一篇對vuejs的v-for遍歷、v-bind動態(tài)改變值、v-if進行判斷的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • vue實現(xiàn)PC端錄音功能的實例代碼

    vue實現(xiàn)PC端錄音功能的實例代碼

    這篇文章主要介紹了vue實現(xiàn)PC端錄音功能的實例代碼,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • Vue3使用Suspense優(yōu)雅地處理異步組件加載的示例代碼

    Vue3使用Suspense優(yōu)雅地處理異步組件加載的示例代碼

    Vue3是Vue.js的最新版本,它帶來了許多令人興奮的新特性和改進,其中一個重要的特性是Suspense,它為我們提供了一種優(yōu)雅地處理異步組件加載和錯誤處理的方式,本文給大家介紹了Vue3使用Suspense優(yōu)雅地處理異步組件加載的示例,需要的朋友可以參考下
    2024-01-01
  • Vue中keep-alive組件作用詳解

    Vue中keep-alive組件作用詳解

    這篇文章主要為大家詳細介紹了Vue中keep-alive組件的作用,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • vue3 vite pinia配置動態(tài)路由、解決刷新頁面路由消失的問題

    vue3 vite pinia配置動態(tài)路由、解決刷新頁面路由消失的問題

    這篇文章主要介紹了vue3 vite pinia配置動態(tài)路由、解決刷新頁面路由消失的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10

最新評論