首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何获得无限滚动,直到所有结果都显示在React中的Elasticsearch JS中

如何获得无限滚动,直到所有结果都显示在React中的Elasticsearch JS中
EN

Stack Overflow用户
提问于 2017-06-01 05:26:29
回答 1查看 1.4K关注 0票数 1

我正在开发一个使用React的搜索引擎用户界面。对于搜索,我使用Elasticsearch。我能够连接并从我的索引中获取结果,但我只能获取我指定大小的结果的数量。我希望启用无限滚动,直到客户端到达结果的末尾。

我需要帮助实现扫描&滚动和分页。

这是我的app.js组件代码

代码语言:javascript
复制
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组件代码:

代码语言:javascript
复制
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;
EN

回答 1

Stack Overflow用户

发布于 2017-06-01 05:41:52

像在Facebook主页中一样,使用对滚动页的AJAX调用;使用一个全局递增的counterVariable,它在ElasticSearch的每个AJAX调用上增加参数,在滚动的AJAX调用中使用参数from记录您想要的size结果文档。对每个ajax调用执行增量。

关于滚动调用AJAX的javaScript,请参考Similar Solved Answer

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44299141

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档