作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我一直在尝试解决此错误,但一直一无所获。我尝试用 subreddit、键、链接、类型和正文替换 .filter() 中的标题,它们都可以正常工作而不会引发错误,只有标题给我错误。在故障排除期间,我还放置了那个 console.log 以查看是否实际存储了某些内容,并且它像应该的那样将标题打印到控制台,但 saved.title 在 .filter 中仍然未定义。我也试过 saved.title.includes 没有 toLowerCase() 无济于事。
有问题的代码
renderPostTitles = () => {
const importantValues = this.props.totalUserSaves.map((saved) => {
return {
subreddit: saved.data.subreddit,
title: saved.data.title,
key: saved.data.id,
link: `https://www.reddit.com${saved.data.permalink}`,
type: saved.kind,
body: saved.data.body
}
})
console.log(importantValues[0].title)
const threadsArray_searched = importantValues.filter(saved => saved.title.toLowerCase().includes(this.props.searchQuery.toLowerCase()) )
更多组件:
import React from 'react';
import { connect } from 'react-redux';
class DisplaySaves extends React.Component {
renderPostTitles = () => {
const importantValues = this.props.totalUserSaves.map((saved) => {
return {
subreddit: saved.data.subreddit,
title: saved.data.title,
key: saved.data.id,
link: `https://www.reddit.com${saved.data.permalink}`,
type: saved.kind,
body: saved.data.body
}
})
const threadsArray_searched = importantValues.filter(saved => saved.title.toLowerCase().includes(this.props.searchQuery.toLowerCase()) )
return threadsArray_searched.map((saved, i) => {
return (
<div key={saved.key}>
<div> {i+1}. </div>
<div> r/{saved.subreddit}: </div>
<p> <a href={saved.link} target="_blank" rel="noopener noreferrer"> {saved.title} </a> </p>
</div>
)
})
}
render () {
return (
<div>
<div>{this.renderPostTitles()}</div>
</div>
)
}
}
const mapStateToProps = state => {
console.log(state)
return {
totalUserSaves: state.userData.totalUserSaves,
searchQuery: state.userData.searchQuery
}
}
export default connect(mapStateToProps)(DisplaySaves);
最佳答案
确保 title 在所有情况下都是一个字符串(一个未定义的元素可能潜入其中),您可以使用默认或字符串构造函数:
return {
title: saved.data.title || '',
或
return {
title: String(saved.data.title),
关于javascript - TypeError: "Cannot read property ' toLowerCase' of undefined"尝试.filter()时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57280522/
我是一名优秀的程序员,十分优秀!