Web Components
Web组件
React和Web组件的构建是为了解决不同的问题。Web组件为可重用组件提供了强大的封装,而React提供了一个声明库来保持DOM与数据同步。这两个目标是相辅相成的。作为开发人员,您可以在Web组件中自由使用React,或者在React中使用Web组件,或者同时使用这两种组件。
大多数使用React的人不使用Web组件,但可能需要使用Web组件,尤其是在使用使用Web组件编写的第三方UI组件时。
在React中使用Web组件
class HelloMessage extends React.Component {
render() {
return <div>Hello <x-search>{this.props.name}</x-search>!</div>;
}
}
注意:Web组件经常公开一个命令式API。例如,一个
video
Web组件可能会公开play()
并pause()
起作用。要访问Web组件的命令式API,您需要使用ref直接与DOM节点交互。如果您使用的是第三方Web组件,最好的解决方案是编写一个React组件,该组件可用作Web组件的包装。Web组件发出的事件可能无法通过React渲染树正确传播。您将需要手动附加事件处理程序来处理React组件中的这些事件。
一个普遍的混淆是Web组件使用“class”而不是“className”。
function BrickFlipbox() {
return (
<brick-flipbox class="demo">
<div>front</div>
<div>back</div>
</brick-flipbox>
}
在您的Web组件中使用React
class XSearch extends HTMLElement {
connectedCallback() {
const mountPoint = document.createElement('span'
this.attachShadow{ mode: 'open' }).appendChild(mountPoint
const name = this.getAttribute('name'
const url = 'https://www.google.com/search?q=' + encodeURIComponent(name
ReactDOM.render(<a href={url}>{name}</a>, mountPoint
}
}
customElements.define('x-search', XSearch
注意:如果您使用Babel转换类,此代码
将
不起作用。请参阅此问题以进行讨论。