ReactJS toLowerCase 不是函数
ReactJS toLowerCase is not a function
我正在通过将我的文本转换为小写并将其索引与 -1 进行比较来进行比较,以便对 ReactJS
中的特定字段具有一些值,但我在 JavaScript 控制台:
Uncaught TypeError: props.filterText.toLowerCase is not a function
var props = this.props;
var rows = this.props.episodes
.filter(function(episode){
return episode.title.toLowerCase().indexOf(props.filterText.toLowerCase()) > -1;
})
.map(function(episode){
return <EpisodeRow key={episode.title} episode={episode}/>
});
看起来克里斯的评论是正确答案:
如果title是字符串,在toLowerCase()之前使用toString():
return episode.title.toString().toLowerCase().indexOf(props.filterText.toString().toLowerCase()) > -1;
我认为 Adam 从评论中得到的答案实际上是正确的,结果解决了我的问题:
.filter(function(episode){
if(episode.title) {
return episode.title.toLowerCase().indexOf(props.filterText.toLowerCase()) > -1;
} else {
return '';
}
})
我想我找到了问题:)
props.filterText 未定义。
=> filterText:"" 必须在放入道具之前在状态中声明
我正在通过将我的文本转换为小写并将其索引与 -1 进行比较来进行比较,以便对 ReactJS
中的特定字段具有一些值,但我在 JavaScript 控制台:
Uncaught TypeError: props.filterText.toLowerCase is not a function
var props = this.props;
var rows = this.props.episodes
.filter(function(episode){
return episode.title.toLowerCase().indexOf(props.filterText.toLowerCase()) > -1;
})
.map(function(episode){
return <EpisodeRow key={episode.title} episode={episode}/>
});
看起来克里斯的评论是正确答案:
如果title是字符串,在toLowerCase()之前使用toString():
return episode.title.toString().toLowerCase().indexOf(props.filterText.toString().toLowerCase()) > -1;
我认为 Adam 从评论中得到的答案实际上是正确的,结果解决了我的问题:
.filter(function(episode){
if(episode.title) {
return episode.title.toLowerCase().indexOf(props.filterText.toLowerCase()) > -1;
} else {
return '';
}
})
我想我找到了问题:)
props.filterText 未定义。 => filterText:"" 必须在放入道具之前在状态中声明