关于Element Popover弹窗关不掉的解决办法

情景:

在 element-ui 中 el-table 中使用Popover弹框 ,根据网上小伙伴提供的方法大部分都是这种:

htm部分:

<el-table-column>
	<template slot-scope="scope">
		<el-popover placement="bottom" title="更多" width="100" trigger="click" :ref="`popover-${scope.$index}`">
		<el-button type="text" size="small" slot="reference">更多el-button>
		el-popover>
   template>
el-table-column>

js部分

canclePopover(scope) {
     
	scope._self.$refs[`test-popover-${
       scope.$index}`].doClose()
},

以上方法即可解决大部分问题

注意:若表格中添加lazy 懒加载,则上面方法无效

所以直接添加以下代码来解决该问题:

document.body.click() // 模拟点击页面其它部分关掉弹层,因为该页面列表使用懒加载导致doClose无效

因为该组件在点击组件以外的body其它部分会消失,所以使用该方法强制出发这个消失条件即可使这个弹框消失

你可能感兴趣的:(web前端,vue)