Как передать функцию обратного вызова в элемент из React? - PullRequest
0 голосов
/ 25 января 2019

Я пытаюсь использовать компонент lit-element в своем проекте React, и я хотел бы передать функцию обратного вызова компоненту lit-element из React, но безуспешно.

Я пробовал несколько разных способов, таких как изменение типа свойства и передача функции в виде строки, но ни один из них не работает.

Код компонента с подсветкой:

import { LitElement, html } from "lit-element";

class MyButton extends LitElement {
  static get properties() {
    return {
      clickHandler: {
        type: String
      },
      bar: {
        type: String
      }
    };
  }

  render() {
    const foo = this.clickHandler; //value is undefined
    const bar = this.bar; //value is "it's bar"
    return html`
      <button @click=${this.clickHandler}>click me</button>
    `;
  }
}

customElements.define("my-button", MyButton);

ответный код стороны:

<my-button clickHandler={() => alert("clicked")} bar="it's bar" />

Я поставил точку останова в секции рендеринга компонента, и я вижу, что значение 'bar' правильно передается, но значение 'clickHandler' не определено.

Кто-нибудь знает, как передать функцию из React в lit-element?

Спасибо!

Ответы [ 2 ]

0 голосов
/ 18 февраля 2019

Что я обнаружил, что работает, это добавление ссылки в компоненте реакции к освещенному элементу, а затем буквально установка свойства для него.

Итак, для следующего JSX:

<some-webcomponent ref={this.myRef}></some-webcomponent>

Вы можете передать свойство «some-webcomponent» в т. Е. ComponentDidMount:

componentDidMount () {
  const element = this.myRef.current;
  element.someCallback = () => // ...
}

Это не слишком красиво, но я бы тоже не считал это хаком. Требуется довольно много шаблонов, хотя: /

Вот полный компонент React для справки:

class MyComponent extends React.Component {   
  constructor(props) {     
    super(props);     
    this.myRef = React.createRef();   
  }   

  render() {     
    return <some-webcomponent ref={this.myRef}></some-webcomponent>;   
  } 

  componentDidMount() {
    const element = this.myRef.current;  
    element.someCallback = () => console.log(“call!”);
  }
}

Где горит элемент:

import { LitElement, html } from "lit-element";  

class SomeWebcomponent extends LitElement {
   static get properties() {    
     return {       
      someCallback: { type: Function }
     };
   }

   render() {     
     return html`       
       <button @click=${this.someCallback}>click me</button>     
     `;   
    } 
}  

customElements.define("some-webcomponent", SomeWebcomponent);
0 голосов
/ 01 февраля 2019

Посмотрите на функцию щелчка по кнопке меню для набора pwa-starter-kit без избыточности по адресу https://github.com/Polymer/pwa-starter-kit/blob/template-no-redux/src/components/my-app.js. Я полагаю, что это пример, который может работать для вас.

...