Portal 传送门
传送门组件。
使用场景
这个组件不提供样式,但它是所有弹层组件的基石。使用 Portal
的好处是不需要自己管理动态插入的节点,防止内存泄露。
代码演示
:::demo 基本用法,第二行是 Portal
插入的,可以在浏览器里审查元素观察Html结构
; ReactDOM;
:::
API
参数 | 说明 | 类型 | 默认值 | 备选值 |
---|---|---|---|---|
children | 必填参数, 只支持一个child | string | ||
selector | 可选参数, 渲染child的DOM节点 | string or DOM Element | 'body' |
合法的CSS selector或者某个DOM节点 |
visible | 可选参数, 是否渲染child | bool | true |
|
className | 可选参数, 自定义额外类名 | string | '' |
|
css | 可选参数, 额外的css样式. 例如, { 'margin-left': '10px' } |
object | {} |
|
prefix | 可选参数, 自定义前缀 | string | 'zent' |
Portal
另外还提供了几个高阶组件(HOC),提供了一些弹层常用的逻辑。
withESCToClose
封装了按ESC关闭的逻辑.
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
visible | 必填参数, 注意这个属性原始的Portal是可选的 | bool | true |
onClose | 必填参数, ESC按下是的回调函数 | func |
;;const Portal = ;
withNonScrollable
封装了禁止container滚动的逻辑.
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
visible | 必填参数, 注意这个属性原始的Portal是可选的 | bool | true |
;;const Portal = ;
组件原理
- 组件的主要功能是把其
child
插入到一个给定的 DOM node中, 并且在组件被unmount
的时候将其child
属性对应的 DOM 节点删除. - 任意 props 被修改后会触发一定程度的重绘,
children
,selector
被修改会导致组件unmount
再mount
;其它props被修改仅更新现有 DOM node 的属性.
已知问题
-
在 Portal 的
children
上使用字符串形式的ref
会报错, 可以使用函数形式的ref
绕过这个问题. 其原因是 Portal 的children
没有owner, 使用函数形式的ref
可以绕过这个问题的原因参见 Here. 此外官方也不鼓励使用字符串形式的ref
. -
15.0.2
版本的 React 有个 bug 会导致某些情况下依赖state
的context
不更新 (参考 example: 02-context), 请等待 React 版本的统一升级.