I have this message: "Uncaught TypeError: Cannot read properties of undefined in React"

huangapple go评论152阅读模式
英文:

I have this message: "Uncaught TypeError: Cannot read properties of undefined in React"

问题

I want to have a main page that displays a list of four accommodations, with the ability to jump to a specific page per accommodation with a click.

I don't see where the error comes from.

My code produces

Uncaught TypeError with a message of "Cannot read properties of undefined (reading 'map')"

APP.js:

  1. import React from 'react';
  2. import { BrowserRouter, Route, Routes } from 'react-router-dom';
  3. import AccommodationList from './components/AccommodationList';
  4. import AccommodationDetails from './components/AccommodationDetails';
  5. //import accommodationsData from './data/accommodations.json';
  6. import './styles/accommodations.css';
  7. export default function App() {
  8. return (
  9. <BrowserRouter>
  10. <Routes>
  11. <Route path="/" element={<AccommodationList/>}/>
  12. <Route path="/accommodation/:id" element={<AccommodationDetails/>}/>
  13. </Routes>
  14. </BrowserRouter>
  15. );
  16. }

ACCOMMODATIONDETAILS.js:

  1. import React from 'react';
  2. import accommodationsData from '../data/accommodations.json';
  3. import '../styles/accommodations.css';
  4. function AccommodationDetails(props) {
  5. const accommodation = accommodationsData.find((a) => a.id === props.match.params.id);
  6. return (
  7. <div>
  8. <h2>{accommodation.title}</h2>
  9. <p>{accommodation.description}</p>
  10. <p>Prix : {accommodation.price}</p>
  11. <img src={accommodation.imageURL} alt={accommodation.altTxt} />
  12. </div>
  13. );
  14. }
  15. export default AccommodationDetails;

ACCOMMODATIONLIST.js

  1. import React from 'react';
  2. import { Link } from 'react-router-dom';
  3. import allaccommodations from '../data/accommodations.json';
  4. import '../styles/accommodations.css';
  5. export default function AccommodationList(props) {
  6. return (
  7. <div>
  8. <div>
  9. <h1>Chez Nestor</h1>
  10. <AccommodationList allaccommodations={allaccommodations} />
  11. </div>
  12. <div className='container'>
  13. {props.allaccommodations.map(accommodation => (
  14. <div key={accommodation.id}>
  15. <figure>
  16. <img src={accommodation.imageURL} alt={accommodation.altTxt} />
  17. <figcaption>
  18. <h2>{accommodation.title}</h2>
  19. <p>{accommodation.description}</p>
  20. <p>Prix : {accommodation.price}</p>
  21. <Link to={`/accommodation/${accommodation.id}`}>Voir plus</Link>
  22. </figcaption>
  23. </figure>
  24. </div>
  25. ))}
  26. </div>
  27. </div>
  28. );
  29. }
  30. console.log(allaccommodations)

I tried changing names, or the term 'element' by 'component'. Where does this error come from, and how can I fix it?

英文:

I want to have a main page that displays a list of four accommodations, with the ability to jump to a specific page per accommodation with a click.

I don't see where the error comes from.

My code produces

> Uncaught TypeError with a message of "Cannot read properties of undefined (reading 'map')"

APP.js:

  1. import React from &#39;react&#39;;
  2. import { BrowserRouter, Route, Routes } from &#39;react-router-dom&#39;;
  3. import AccommodationList from &#39;./components/AccommodationList&#39;;
  4. import AccommodationDetails from &#39;./components/AccommodationDetails&#39;;
  5. //import accommodationsData from &#39;./data/accommodations.json&#39;;
  6. import &#39;./styles/accommodations.css&#39;;
  7. export default function App() {
  8. return (
  9. &lt;BrowserRouter&gt;
  10. &lt;Routes&gt;
  11. &lt;Route path=&quot;/&quot; element={&lt;AccommodationList/&gt;}/&gt;
  12. &lt;Route path=&quot;/accommodation/:id&quot; element={&lt;AccommodationDetails/&gt;}/&gt;
  13. &lt;/Routes&gt;
  14. &lt;/BrowserRouter&gt;
  15. );
  16. }

ACCOMMODATIONDETAILS.js:

  1. import React from &#39;react&#39;;
  2. import accommodationsData from &#39;../data/accommodations.json&#39;;
  3. import &#39;../styles/accommodations.css&#39;;
  4. function AccommodationDetails(props) {
  5. const accommodation = accommodationsData.find((a) =&gt; a.id === props.match.params.id);
  6. return (
  7. &lt;div&gt;
  8. &lt;h2&gt;{accommodation.title}&lt;/h2&gt;
  9. &lt;p&gt;{accommodation.description}&lt;/p&gt;
  10. &lt;p&gt;Prix : {accommodation.price}&lt;/p&gt;
  11. &lt;img src={accommodation.imageURL} alt={accommodation.altTxt} /&gt;
  12. &lt;/div&gt;
  13. );
  14. }
  15. export default AccommodationDetails;

ACCOMMODATIONLIST.js

  1. import React from &#39;react&#39;;
  2. import { Link } from &#39;react-router-dom&#39;;
  3. import allaccommodations from &#39;../data/accommodations.json&#39;;
  4. import &#39;../styles/accommodations.css&#39;;
  5. export default function AccommodationList(props) {
  6. return (
  7. &lt;div&gt;
  8. &lt;div&gt;
  9. &lt;h1&gt;Chez Nestor&lt;/h1&gt;
  10. &lt;AccommodationList allaccommodations={allaccommodations} /&gt;
  11. &lt;/div&gt;
  12. &lt;div className=&#39;container&#39;&gt;
  13. {props.allaccommodations.map(accommodation =&gt; (
  14. &lt;div key={accommodation.id}&gt;
  15. &lt;figure&gt;
  16. &lt;img src={accommodation.imageURL} alt={accommodation.altTxt} /&gt;
  17. &lt;figcaption&gt;
  18. &lt;h2&gt;{accommodation.title}&lt;/h2&gt;
  19. &lt;p&gt;{accommodation.description}&lt;/p&gt;
  20. &lt;p&gt;Prix : {accommodation.price}&lt;/p&gt;
  21. &lt;Link to={`/accommodation/${accommodation.id}`}&gt;Voir plus&lt;/Link&gt;
  22. &lt;/figcaption&gt;
  23. &lt;/figure&gt;
  24. &lt;/div&gt;
  25. ))}
  26. &lt;/div&gt;
  27. &lt;/div&gt;
  28. );
  29. }
  30. console.log(allaccommodations)

I tried changing names, or the term 'element' by 'component'. Where does this error come from, and how can I fix it?

答案1

得分: 1

问题起始于 AccommodationList,在这里未向组件传递 props,所以 props.allaccommodations 是未定义的。

您还似乎在递归渲染 &lt;AccommodationList /&gt; 组件,这似乎是不正确且不必要的。它可以被删除。

假设您想要渲染导入的 allaccommodations,它不会位于 props 对象上,应该直接进行映射。

示例:

  1. &lt;Route path=&quot;/&quot; element={&lt;AccommodationList /&gt;} /&gt; // &lt;-- 不传递 props
  1. import React from &#39;react&#39;;
  2. import { Link } from &#39;react-router-dom&#39;;
  3. import allaccommodations from &#39;../data/accommodations.json&#39;; // &lt;-- 在这里导入
  4. import &#39;../styles/accommodations.css&#39;;
  5. export default function AccommodationList() { // &lt;-- 没有要引用的 props
  6. return (
  7. &lt;div&gt;
  8. &lt;div&gt;
  9. &lt;h1&gt;Chez Nestor&lt;/h1&gt;
  10. &lt;/div&gt;
  11. &lt;div className=&#39;container&#39;&gt;
  12. {allaccommodations.map(accommodation =&gt; ( // &lt;-- 在这里引用
  13. &lt;div key={accommodation.id}&gt;
  14. &lt;figure&gt;
  15. &lt;img src={accommodation.imageURL} alt={accommodation.altTxt} /&gt;
  16. &lt;figcaption&gt;
  17. &lt;h2&gt;{accommodation.title}&lt;/h2&gt;
  18. &lt;p&gt;{accommodation.description}&lt;/p&gt;
  19. &lt;p&gt;Prix : {accommodation.price}&lt;/p&gt;
  20. &lt;Link to={`/accommodation/${accommodation.id}`}&gt;
  21. Voir plus
  22. &lt;/Link&gt;
  23. &lt;/figcaption&gt;
  24. &lt;/figure&gt;
  25. &lt;/div&gt;
  26. ))}
  27. &lt;/div&gt;
  28. &lt;/div&gt;
  29. );
  30. }
英文:

The issue starts in AccommodationList where no props are passed to the component, so props.allaccommodations is undefined.

You also appear to be recursively rendering the &lt;AccommodationList /&gt; component, which seems incorrect and unnecessary. It can likely be removed.

Assuming you want to render the imported allaccommodations it won't be located on the props object, it should be mapped directly.

Example:

  1. &lt;Route path=&quot;/&quot; element={&lt;AccommodationList /&gt;} /&gt; // &lt;-- no passed props
  1. import React from &#39;react&#39;;
  2. import { Link } from &#39;react-router-dom&#39;;
  3. import allaccommodations from &#39;../data/accommodations.json&#39;; // &lt;-- imported here
  4. import &#39;../styles/accommodations.css&#39;;
  5. export default function AccommodationList() { // &lt;-- no props to reference
  6. return (
  7. &lt;div&gt;
  8. &lt;div&gt;
  9. &lt;h1&gt;Chez Nestor&lt;/h1&gt;
  10. &lt;/div&gt;
  11. &lt;div className=&#39;container&#39;&gt;
  12. {allaccommodations.map(accommodation =&gt; ( // &lt;-- referenced here
  13. &lt;div key={accommodation.id}&gt;
  14. &lt;figure&gt;
  15. &lt;img src={accommodation.imageURL} alt={accommodation.altTxt} /&gt;
  16. &lt;figcaption&gt;
  17. &lt;h2&gt;{accommodation.title}&lt;/h2&gt;
  18. &lt;p&gt;{accommodation.description}&lt;/p&gt;
  19. &lt;p&gt;Prix : {accommodation.price}&lt;/p&gt;
  20. &lt;Link to={`/accommodation/${accommodation.id}`}&gt;
  21. Voir plus
  22. &lt;/Link&gt;
  23. &lt;/figcaption&gt;
  24. &lt;/figure&gt;
  25. &lt;/div&gt;
  26. ))}
  27. &lt;/div&gt;
  28. &lt;/div&gt;
  29. );
  30. }

答案2

得分: 0

确保 props.allaccommodations 已经定义并赋有某个值。然后尝试在其上使用 map

示例:

  1. {
  2. props.allaccommododations &&
  3. props.allaccommodations.map((accommodation) => (
  4. <div key={accommodation.id}>
  5. <figure>
  6. <img src={accommodation.imageURL} alt={accommodation.altTxt} />
  7. <figcaption>
  8. <h2>{accommodation.title}</h2>
  9. <p>{accommodation.description}</p>
  10. <p>Prix : {accommodation.price}</p>
  11. <Link to={`/accommodation/${accommodation.id}`}>Voir plus</Link>
  12. </figcaption>
  13. </figure>
  14. </div>
  15. ));
  16. }
英文:

Make sure props.allaccommodations is defined with some value.<br>
Then try using map on it.

Example:

  1. {
  2. props.allaccomodations &amp;&amp;
  3. props.allaccommodations.map((accommodation) =&gt; (
  4. &lt;div key={accommodation.id}&gt;
  5. &lt;figure&gt;
  6. &lt;img src={accommodation.imageURL} alt={accommodation.altTxt} /&gt;
  7. &lt;figcaption&gt;
  8. &lt;h2&gt;{accommodation.title}&lt;/h2&gt;
  9. &lt;p&gt;{accommodation.description}&lt;/p&gt;
  10. &lt;p&gt;Prix : {accommodation.price}&lt;/p&gt;
  11. &lt;Link to={`/accommodation/${accommodation.id}`}&gt;Voir plus&lt;/Link&gt;
  12. &lt;/figcaption&gt;
  13. &lt;/figure&gt;
  14. &lt;/div&gt;
  15. ));
  16. }

huangapple
  • 本文由 发表于 2023年3月7日 06:24:55
  • 转载请务必保留本文链接:https://go.coder-hub.com/75656397.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定