【发布时间】:2019-05-08 15:07:21
【问题描述】:
我尝试在我的大多数项目中使用 Preact,但现在我需要使用 React 组件。我不希望这要求我切换框架。我可以做些什么来从我的 Preact 代码渲染 React 组件?
【问题讨论】:
我尝试在我的大多数项目中使用 Preact,但现在我需要使用 React 组件。我不希望这要求我切换框架。我可以做些什么来从我的 Preact 代码渲染 React 组件?
【问题讨论】:
Preact 提供了一个名为preact-compat 的兼容层。
您可以使用您的模块捆绑器为 react 和 react-dom 导入别名以使用 preact-compat,这应该允许您在未修改的 Preact 应用程序中使用 React 代码。
这是一个 Webpack 示例,取自 preact-compat 文档:
{
// ...
resolve: {
alias: {
'react': 'preact-compat',
'react-dom': 'preact-compat',
// Not necessary unless you consume a module using `createClass`
'create-react-class': 'preact-compat/lib/create-react-class',
// Not necessary unless you consume a module requiring `react-dom-factories`
'react-dom-factories': 'preact-compat/lib/react-dom-factories'
}
}
// ...
}
编辑: 正如 @pmkro 在 cmets 中所指出的,from Preact 10.0 onwards、preact-compat 正在移回核心 preact 包中,并将通过 preact/compat 提供。
【讨论】:
preact 10 而改变。这对 8.x 有效,但对于 X,它已更改为 preact/compat,并且它随包的其余部分一起提供。