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。例如,一个videoWeb组件可能会公开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转换类,此代码不起作用。请参阅此问题以进行讨论。