我正在开发一个使用React的搜索引擎用户界面。对于搜索,我使用Elasticsearch。我能够连接并从我的索引中获取结果,但我只能获取我指定大小的结果的数量。我希望启用无限滚动,直到客户端到达结果的末尾。
我需要帮助实现扫描&滚动和分页。
这是我的app.js组件代码
import React from 'react';
import Header from './header';
import Footer from './footer';
import SearchResults from './searchresults';
import elasticsearch from 'elasticsearch';
let client = new elasticsearch.Client({
host: 'localhost:9200',
log: 'trace'
})
class App extends React.Component {
constructor(props) {
super(props);
this.state = { results: [], search_query: '*' }
this.handleChange = this.handleChange.bind(this);
}
handleChange ( event ) {
var search_query = event.target.value;
var size = 20;
client.search({
index: 'photos',
type: 'photo',
q: search_query,
size: size
}).then(function ( body ) {
this.setState({ results: body.hits.hits })
}.bind(this), function ( error ) {
console.trace( error.message );
});
}
render () {
return (
<div className="main">
<Header />
<div className="row test">
<div className="col-xs-4"></div>
<div className="col-xs-4">
<div className="row">
<div className="col-xs-12">
<input id="search" className="form-control" type="text" placeholder="Start Searching" name="search" onChange={ this.handleChange }></input>
</div>
</div>
</div>
<div className="col-xs-4"></div>
<br />
</div>
<div className="test bclass">
<SearchResults results={ this.state.results } />
<button type="button" className="btn btn-default">Load More</button>
</div>
<Footer />
</div>
)
}
}
export default App;下面是我的searchresults.js组件代码:
import React from 'react';
import PropTypes from 'prop-types';
import LazyLoad from 'react-lazy-load';
let i = 1;
class SearchResults extends React.Component {
constructor(props) {
super(props);
this.state = { results: [] }
}
render () {
return (
<div className="search_results">
<hr />
<ul>
{ this.props.results.map((result) => {
return (
<li key={ result._id + i++}>
<LazyLoad className="lazy">
<img className="image" src={result._source.file_name} alt="Search Result" />
</LazyLoad>
</li>
) }) }
</ul>
</div>
)
}
}
SearchResults.propTypes = {
results: PropTypes.array
}
export default SearchResults;发布于 2017-06-01 05:41:52
像在Facebook主页中一样,使用对滚动页的AJAX调用;使用一个全局递增的counterVariable,它在ElasticSearch的每个AJAX调用上增加参数,在滚动的AJAX调用中使用参数from记录您想要的size结果文档。对每个ajax调用执行增量。
关于滚动调用AJAX的javaScript,请参考Similar Solved Answer。
https://stackoverflow.com/questions/44299141
复制相似问题