[我的ReactJS中有一个博客部分,它从无头CMS提取帖子,页面使用分页,并且一切正常,但是,在每个帖子项目中,我都调用了一个组件来输入作者的名字>因此,基本上我提取了一个ID从无头的api中,我将其传递给组件并返回作者的名字。
这在第一轮工作正常,但是无论何时我使用页面分页,无论道具传递的信息如何,它都不会从组件中带回其他任何东西。这是我的代码;
博客页面;
getPosts(){
if(this.state.posts.length){
return this.state.posts.map((content,index) => {
var url = content.Title.replace(/[^\w\s]/gi, '');
url = url.replace(/\s+/g, '-').toLowerCase();
return(
<Col md={4} className="mb-4" key={index}>
{({isVisible}) =>
<Card>
<Card.Body>
<Link to={{ pathname: `/posts/${url}` }}>
<Card.Title>{this.truncateOnWord(content.Title,50)}</Card.Title>
</Link>
<Card.Text>{this.truncateOnWord(content.SEOMetaDescription,150)}</Card.Text>
</Card.Body>
<Card.Footer>
<PortraitTest displayFromAPIID={content.Author._id}></PortraitTest>
</Card.Footer>
</Card>
}
</Col>
);
})
}
}
handlePageClick = data => {
var myElement = document.getElementById('articles');
var topPos = myElement.offsetTop;
window.scrollTo({top: topPos, behavior: 'smooth'});
var selected = data.selected + 1;
var offset = ((selected * this.state.perPage) - this.state.perPage);
var limit = (this.state.perPage * selected);
this.setState({ offset: offset, limit: limit }, () => {
this.loadAPI();
});
};
render() {
return (
<div>
<CardDeck>
{this.getPosts()}
</CardDeck>
<ReactPaginate
previousLabel='«'
previousClassName={ 'previousBtn'}
nextLabel='»'
nextClassName={'nextBtn'}
breakLabel={'...'}
breakClassName={'break-me'}
activeClassName={'active'}
pageClassName={'page-item'}
pageLinkClassName={'page-link'}
containerClassName={'pagination'}
subContainerClassName={'pages pagination'}
pageCount={this.state.pageCount}
marginPagesDisplayed={2}
pageRangeDisplayed={5}
onPageChange={this.handlePageClick}
/>
</div>
);
}
作者成分:
import React, { Component } from 'react';
class PortraitTest extends Component {
constructor(props) {
super(props);
this.state = {
displayFromAPIID: this.props.displayFromAPIID,
name: null,
apiID: null,
}
this.portraits = [
{
'name': 'Name 1',
'apiID': '5d84ba9c0a011064444a243e',
},
{
'name': 'Name 2',
'apiID': '5d84bad40a011064444a2441',
},
{
'name': 'Name 3',
'apiID': '5d84d4d00a011064444a244d',
},
{
'name': 'Name 4',
'apiID': '5d84ba480a011064444a243a',
},
{
'name': 'Name 5',
'apiID': '5d84d4900a011064444a244c',
},
{
'name': 'Name 6',
'apiID': '5d84baeb0a011064444a2442',
},
{
'name': 'Name 7',
'apiID': '5d84baaf0a011064444a243f',
},
{
'name': 'Name 8',
'apiID': '5d84ba720a011064444a243c',
},
{
'name': 'Name 9',
'apiID': '5d84d4120a011064444a244a',
},
{
'name': 'Name 10',
'apiID': '5d84d4640a011064444a244b',
},
{
'name': 'Name 11',
'apiID': '5d84b93a0a011064444a2439',
},
{
'name': 'Name 12',
'apiID': '5d84d3b60a011064444a2449',
},
{
'name': 'Name 13',
'apiID': '5d84bac00a011064444a2440',
},
{
'name': 'Name 14',
'apiID': '5d84ba870a011064444a243d',
},
{
'name': 'Name 15',
'apiID': '5d84ba5e0a011064444a243b',
},
{
'name': 'Name 16',
'apiID': '5dd7cbf984b07d000dc63b2e',
}
]
}
returnObj(){
for (var i = 0; i < this.portraits.length; i++) {
if(this.state.displayFromAPIID === Object.values(this.portraits[i])[1]){
return(
<div>
<p><b>{Object.values(this.portraits[i])[0]}<br/>{Object.values(this.portraits[i])[1]}<br/>{this.props.displayFromAPIID}</b></p>
</div>
)
}
}
}
render() {
return (
<div>
{this.returnObj()}
</div>
);
}
}
export default PortraitTest;
下面是输出到博客页面的组件的屏幕快照。
有人对我要去哪里有任何想法吗?
[请注意,实际上博客文章所在的页面非常好,并且可以按预期工作,从API提取正确的数据并且分页效果很好,这是我要求提供信息的组件无法正常工作。
谢谢
componentDidUpdate(prevProps) {
if (this.props.displayFromAPIID !== prevProps.displayFromAPIID) {
this.setState({displayFromAPIID: this.props.displayFromAPIID});
}
}