[英]Issues with an Array.forEach
Hope someone here would be able to help me out.希望这里有人能帮助我。
I am trying to build an Owl-Carousel from an array of objects.我正在尝试从一组对象构建一个 Owl-Carousel。 but for some reason the array is not been recognized, would appreciate if someone could help to find the mistake I have made here.
但由于某种原因,该数组未被识别,如果有人能帮助找到我在这里犯的错误,将不胜感激。
The error messages I am getting is:我收到的错误消息是:
'item' is not defined.
“项目”未定义。 and 'tv' is assigned a value but never used.
并且“tv”被分配了一个值,但从未使用过。
Here you have the code:这里有代码:
const tv = [
{
name: 'Meu Pedacinho de Chao 01',
personagem: 'Barbeiro',
ano: 2014,
de: 'Benedito Ruy Barbosa',
img: { mpc1 },
alt: 'Meu Pedacinho de Chao 01'
}...
]
export class Televisao extends Component {
render() {
return (
<div class='container-fluid' >
tv.forEach(function (item) {
<OwlCarousel items={3}
className="owl-theme"
loop
nav
margin={8} >
<div className='item card' >
<img className='"card-img-top" ' src={item.img} alt={item.alt} />
<div className='card-body' >
<h5 className="card-title" > ${item.name} </h5>
< p class="card-text" > ${item.personagem} </p>
< p class="card-text" > ${item.ano} </p>
< p class="card-text" > ${item.de} </p>
</div >
</div >
</OwlCarousel >
}
</div>
)
}
}
export default Televisao;
forEach
executes a function for every element, you want map
in this case (and have to return the JSX from the function, which you're not currently doing) forEach
为每个元素执行一个函数,在这种情况下你想要map
(并且必须从函数返回 JSX,你目前没有这样做)
const tv = [
{
name: 'Meu Pedacinho de Chao 01',
personagem: 'Barbeiro',
ano: 2014,
de: 'Benedito Ruy Barbosa',
img: { mpc1 },
alt: 'Meu Pedacinho de Chao 01'
}...
]
export class Televisao extends Component {
render() {
return (
<div class='container-fluid' >
tv.map(function (item) {
return (<OwlCarousel items={3}
className="owl-theme"
loop
nav
margin={8} >
<div className='item card' >
<img className='"card-img-top" ' src={item.img} alt={item.alt} />
<div className='card-body' >
<h5 className="card-title" > ${item.name} </h5>
< p class="card-text" > ${item.personagem} </p>
< p class="card-text" > ${item.ano} </p>
< p class="card-text" > ${item.de} </p>
</div >
</div >
</OwlCarousel >)
}
</div>
)
}
}
export default Televisao;
Any expression Javascript should be inside curly brackets "{}" and replace forEach by map cause forEach doesn't return anything and I notice that you use a function and doesn't return anything to fix this you can add return before OwlCarousel component or use arrow function with parentheses.任何表达式 Javascript 都应该在大括号“{}”内并用 map 替换 forEach 因为 forEach 不返回任何内容,我注意到您使用函数并且不返回任何内容来解决此问题您可以在 OwlCarousel 组件之前添加 return 或使用带括号的箭头函数。
const tv = [
{
name: 'Meu Pedacinho de Chao 01',
personagem: 'Barbeiro',
ano: 2014,
de: 'Benedito Ruy Barbosa',
img: { mpc1 },
alt: 'Meu Pedacinho de Chao 01'
}...
]
export class Televisao extends Component {
render() {
return (
<div className="container-fluid">
{tv.map((item)=>(
<OwlCarousel items={3}
className="owl-theme"
loop
nav
margin={8}>
<div className="item card" >
<img className="card-img-top" src={item.img} alt={item.alt} />
<div className="card-body">
<h5 className="card-title">{item.name}</h5>
<p className="card-text">{item.personagem}</p>
<p className="card-text">{item.ano}</p>
<p className="card-text">{item.de}</p>
</div>
</div>
</OwlCarousel>
)}
</div>
)
}
}
export default Televisao;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.