
巧用teleport解决element-ui drawer组件的绝对定位难题
Element-UI的Drawer组件默认使用display: none;隐藏内容,这会导致其子元素无法使用position: fixed;进行绝对定位。 为了解决这个问题,Vue的Teleport功能提供了一个优雅的解决方案。
Teleport可以将组件的渲染目标更改到DOM树中的其他位置。在本例中,我们将Drawer内部的div元素渲染到标签下。 这样一来,即使Drawer隐藏,该div元素仍然保持在页面中,从而实现绝对定位。
实现方法如下:
我是悬浮在右下角的 divimport { ref } from 'vue';import { ElDrawer } from 'element-ui';export default { components: { ElDrawer }, setup() { const drawerVisible = ref(false); return { drawerVisible }; }};
通过将#floating-div元素使用Teleport移动到,我们成功绕过了display: none;的限制,实现了即使Drawer隐藏,子元素也能保持绝对定位悬浮的效果。
以上就是如何使用Teleport解决Element-UI Drawer隐藏后子元素无法绝对定位的问题?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1561228.html
微信扫一扫
支付宝扫一扫