React Algolia 即时搜索 connectSearchBox

React Algolia instantsearch connectSearchBox

我正在使用 Algolia React InstantSearch 和 connectSearchBox 创建自定义输入。我目前这样做的方式如下:

const MySearchBox = connectSearchBox(({currentRefinement, refine}) => {
    return (
      <input
        type="text"
        placeholder="Search"
        value={currentRefinement}
        onFocus={()=> props.onFocus()}
        onBlur={()=> props.onBlur()}
        onChange={(e) => {refine(e.target.value)}}
      />
    );
  });



然后用下面的代码来实例化:

<InstantSearch
  onSearchStateChange={(result) => this.onSearchChange(result)}
  appId={appId}
  apiKey={apiKey}
  indexName={index}>
  <MySearchBox/>
</InstantSearch>

这非常有效。但是,我想做的是能够将道具传递给 MySearchBox。所以我做了这样的事情:

const MySearchBox = (props) => {
  connectSearchBox(({currentRefinement, refine}) => {
    return (
      <input
        type="text"
        ....
      />
    );
  })
}

或者这样:

const MySearchBox = React.createClass({
  render() {
    return (
      connectSearchBox(({currentRefinement, refine}) => {
        return (
          <input
            type="text"
          />
        );
      })
    )
  }
});

但是,运行这段代码,我得到以下错误:

MYSEARCHBOX(...): A VALID REACT ELEMENT (OR NULL) MUST BE RETURNED. YOU MAY HAVE RETURNED UNDEFINED, AN ARRAY OR SOME OTHER INVALID OBJECT.

请问我到底有什么方法可以把props传给MySearchBox呢?

您只需将道具传递给您的自定义搜索框并像这样检索它们:

自定义搜索框:

const MySearchBox = connectSearchBox(({ onFocus, onBlur, currentRefinement, refine }) => {
  return (
    <input
      type="text"
      placeholder="Search"
      value={currentRefinement}
      onFocus={() => onFocus()}
      onBlur={() => onBlur()}
      onChange={e => {
        refine(e.target.value);
      }}
    />
  );
});

用法:

<MySearchBox onFocus={} onBlur={} />

此外,我们现在正在转发传递给 <SearchBox> 小部件的 on* 事件。