©
本文档使用
php.cn手册 发布
React和Web组件的构建是为了解决不同的问题。Web组件为可重用组件提供了强大的封装,而React提供了一个声明库来保持DOM与数据同步。这两个目标是相辅相成的。作为开发人员,您可以在Web组件中自由使用React,或者在React中使用Web组件,或者同时使用这两种组件。
大多数使用React的人不使用Web组件,但可能需要使用Web组件,尤其是在使用使用Web组件编写的第三方UI组件时。
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> ); }
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转换类,此代码将不起作用。请参阅此问题以进行讨论。