博客
关于我
react 组件进阶之 Portals
阅读量:687 次
发布时间:2019-03-17

本文共 808 字,大约阅读时间需要 2 分钟。

含义

Portals 翻译为门户,但是感觉不对。作用类似插槽,但是不是vue 里面的插槽哦,有点像vue3 里面的 teleport,两者的作用都是将对于的虚拟dom 插入到真实dom的某个位置上。这里不讲两者的区别,只讲 Portals 的用法

语法

ReactDOM.createPortal(child, container)

第一个参数(child)是任何可渲染的 React 子元素,例如一个元素,字符串或 fragment。第二个参数(container)是一个 DOM 元素。

用法

import React, {    PureComponent } from 'react'import ReactDOM from 'react-dom'function CompB() {     return (    
我是子组件B
)}function CompA() { return ReactDOM.createPortal( (
我是子组件A
), document.querySelector('#modal') as Element )}export default class TestComPortals extends PureComponent { render() { return (
我是挂载在跟组件的
) }}

效果

在这里插入图片描述

在这里插入图片描述

使用注意:

  1. 使用 Portals 改变的是真实dom结构,虚拟的dom 树是不会有变化的
  2. 注意改变的事件冒泡, 由于react 中的事件是由react 包装过后的,所以他的真实事件冒泡是通过虚拟的dom 树里面来进行冒泡的。
    在这里插入图片描述

效果

在这里插入图片描述

转载地址:http://qfjhz.baihongyu.com/

你可能感兴趣的文章
Navicat怎样筛选数据
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>
navicat连接远程mysql数据库
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
navigationController
查看>>
NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
查看>>
NBear简介与使用图解
查看>>
Vue过滤器_使用过滤器进行数据格式化操作---vue工作笔记0015
查看>>
Ncast盈可视 高清智能录播系统 IPSetup.php信息泄露+RCE漏洞复现(CVE-2024-0305)
查看>>
NCNN中的模型量化解决方案:源码阅读和原理解析
查看>>
NCNN源码学习(1):Mat详解
查看>>