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*
事件。
我正在使用 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*
事件。