Vue3中多個彈窗同時出現(xiàn)的解決思路
彈窗或者說對話框是我們在開發(fā)系統(tǒng)或者頁面很常用的元素,所以博主想對出現(xiàn)多個彈窗的情況下的解決思路進行一個整理
有時候我們一個頁面可能存在多個彈窗,當多個彈窗出現(xiàn)的時候可能屏幕就變的很黑
如下圖所示:
取消遮罩層
對此我們可以使用組件原生的屬性modal去取消遮罩層
但問題是
如果存在兩個一樣大小的彈窗
比如我在一個500pxX500px的彈窗中有一個按鈕
是打開另一個大小為500pxX500px的彈窗
但是我又想存在一層遮罩層(按情況此時是兩層遮罩層)以表示目前是打開了彈窗,面對這種情況我們應(yīng)該怎么解決呢?
打開一層彈窗的同時隱藏另一個彈窗
我們可以給第一個打開的彈窗設(shè)置一個display:none
屬性
思路如圖所示:
彈窗冒泡如何解決
這個需求的存在是一個比較特殊的情況,如果存在一個頁面,點擊這個頁面的任何地方都會打開一個彈窗,同時這個頁面中有一個按鈕可以打開另一個彈窗
如下圖所示:
這個情況我們就可以在button的綁定函數(shù)中加上.stop
,即
<button @click.stop='打開彈窗' />
這樣的話就不會出現(xiàn)兩個彈窗了
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue如何通過props方式在子組件中獲取相應(yīng)的對象
這篇文章主要介紹了vue如何通過props方式在子組件中獲取相應(yīng)的對象,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04Vue組件間的通信pubsub-js實現(xiàn)步驟解析
這篇文章主要介紹了Vue組件間的通信pubsub-js實現(xiàn)原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03