CSS 解決z-index上層元素遮擋下層元素點擊事件問題

  • 2019 年 12 月 12 日
  • 筆記

解決z-index上層元素遮擋下層元素點擊事件問題

開發環境

Win 10

element-ui "2.8.2"

Vue 2.9.6

需求描述

如下,有以下介面,其中右側邊時一個ElementUI Dialog模態對話框,希望在對話框上執行點擊操作時,不會點擊到被對話框遮擋的頁面的按鈕,同時,也希望可以點擊對話框區域外的其它頁面元素

html元素結構如下

解決方案

為被遮擋元素上層使用z-index屬性的元素添加以下樣式:

pointer-events: none;

這樣點擊事件就能穿透上層元素,可點擊到被遮擋元素,但是此時,上層元素無法響應點擊事件

然後為被遮擋元素添加以下樣式,讓上層元素可以響應點擊事件(僅讓被遮擋元素自身可以響應點擊事件):

pointer-events: auto;

程式碼實現

<template>      <!-- 用例詳情組件 -->      <div class="case-dialog-div">          <el-dialog              ref="caseDialog"              :title="caseDialogTitle"              :visible="caseDialogVisible"              :fullscreen="fullscreen"              :modal="false"              :close-on-click-modal="false"              :before-close="beforeClose"              custom-class="case-dialog-class"              @close="onCloseDialog"          >              ...略          </el-dialog>      </div>  </template>  <style lang="scss">  // 修改dialog body樣式//該樣式不能放置.case-dialog-div下,否則 全螢幕 功能不起作用  .case-dialog-class {      position: fixed;      pointer-events: auto; // dialog本身區域不讓「穿透點擊」      display: block;      height: 100%;      width: 50%; // width: 959px;      right: 0px;      margin-top: 0px !important;      padding: 10px !important;      overflow: auto;  }  .case-dialog-div {      .el-dialog__wrapper {          pointer-events: none; // 可點擊dialog區域外的html元素      }      ...略  }  </style>