اذهب إلى المحتوى
  • 0

ظهر لي هذا الخطا عند الحفظ البيانات في localStorage

Omar Hassan10

السؤال

Recommended Posts

  • 0

المشكلة حسب الصورة التي أرفقتها تكمن في أن المتغير `notes` ليس مصفوفة بشكل صحيح، وبالتالي لا يمكن استخدام الميثود `map` عليه.

للتحقق من ذلك، يمكنك إضافة بعض التحققات في الكود للتأكد من أن `notes` هو مصفوفة قبل استخدام `map` عليها، يمكنك فعل ذلك عن طريق إضافة شرط قبل استخدام `map` كما يلي:

<NoteList>
  {Array.isArray(notes) && notes.map((note) => (
    <NoteItems
      key={note.id}
      title={note.title}
      noteClicked={() => selectedNoteHandler(note.id)}
      active={selectedNote === note.id}
    />
  ))}
</NoteList>

وهكذا سيتأكد أن `notes` فعلا مصفوفة قبل استخدام `map`، وإلا فسيتم تجاهل استخدام `map`، وهذا سيمنع ظهور الخطأ `map is not a function` في حال كان `notes` ليس مصفوفة.

أرجو رفع ملفات المشروع كاملة، كي أساعدك على حل المشكلة بشكل صحيح. 

تم التعديل في بواسطة ياسر مسكين
رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0

المشكلة لديك هي أنّ المصفوفة notes ليست مصفوفة وبالتالي ميثود map لا يمكن التعرف عليها لأنها خاصة بالمصفوفات، وذلك ما يظهر لك map is not a function.

لذا تأكد من تمرير notes بشكل صحيح وأنها مصفوفة يمكنك طباعتها بالكونسول للتأكد.

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0
بتاريخ 11 ساعة قال ياسر مسكين:

المشكلة حسب الصورة التي أرفقتها تكمن في أن المتغير `notes` ليس مصفوفة بشكل صحيح، وبالتالي لا يمكن استخدام الميثود `map` عليه.

للتحقق من ذلك، يمكنك إضافة بعض التحققات في الكود للتأكد من أن `notes` هو مصفوفة قبل استخدام `map` عليها، يمكنك فعل ذلك عن طريق إضافة شرط قبل استخدام `map` كما يلي:

<NoteList>
  {Array.isArray(notes) && notes.map((note) => (
    <NoteItems
      key={note.id}
      title={note.title}
      noteClicked={() => selectedNoteHandler(note.id)}
      active={selectedNote === note.id}
    />
  ))}
</NoteList>

وهكذا سيتأكد أن `notes` فعلا مصفوفة قبل استخدام `map`، وإلا فسيتم تجاهل استخدام `map`، وهذا سيمنع ظهور الخطأ `map is not a function` في حال كان `notes` ليس مصفوفة.

أرجو رفع ملفات المشروع كاملة، كي أساعدك على حل المشكلة بشكل صحيح. 

 

hsoub-logo.png

App.css App.js App.test.js index.js NoteContainer.js NoteForm.js NoteItems.js NoteList.js index.js index.css index.js logo.svg reportWebVitals.js setupTests.js

بتاريخ 11 ساعة قال Mustafa Suleiman:

المشكلة لديك هي أنّ المصفوفة notes ليست مصفوفة وبالتالي ميثود map لا يمكن التعرف عليها لأنها خاصة بالمصفوفات، وذلك ما يظهر لك map is not a function.

لذا تأكد من تمرير notes بشكل صحيح وأنها مصفوفة يمكنك طباعتها بالكونسول للتأكد.

لا يوجد مشكله في notes
هذا هو الكود
 

  useEffect(() => {

    if (localStorage.getItem("notes")) {

      setNotes(JSON.parse(localStorage.getItem("notes")));

    } else {

      localStorage.setItem("notes", JSON.stringify([]));

    }

  }, []);

 

  const saveNotesToLocalStorage = (key, value) => {

    localStorage.setItem(key, JSON.stringify(value));

  };

لما كتبت هذا الكود حدث الخطا
setNotes(JSON.parse(localStorage.getItem("notes")));
لما اجي اشيل setNotes الخطا بيتشال

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0
بتاريخ On 7‏/3‏/2024 at 23:07 قال ياسر مسكين:

المشكلة حسب الصورة التي أرفقتها تكمن في أن المتغير `notes` ليس مصفوفة بشكل صحيح، وبالتالي لا يمكن استخدام الميثود `map` عليه.

للتحقق من ذلك، يمكنك إضافة بعض التحققات في الكود للتأكد من أن `notes` هو مصفوفة قبل استخدام `map` عليها، يمكنك فعل ذلك عن طريق إضافة شرط قبل استخدام `map` كما يلي:

<NoteList>
  {Array.isArray(notes) && notes.map((note) => (
    <NoteItems
      key={note.id}
      title={note.title}
      noteClicked={() => selectedNoteHandler(note.id)}
      active={selectedNote === note.id}
    />
  ))}
</NoteList>

وهكذا سيتأكد أن `notes` فعلا مصفوفة قبل استخدام `map`، وإلا فسيتم تجاهل استخدام `map`، وهذا سيمنع ظهور الخطأ `map is not a function` في حال كان `notes` ليس مصفوفة.

أرجو رفع ملفات المشروع كاملة، كي أساعدك على حل المشكلة بشكل صحيح. 

لم يتم الرد علي ؟؟

رابط هذا التعليق
شارك على الشبكات الإجتماعية

  • 0
بتاريخ 14 دقائق مضت قال Omar Hassan10:

لم يتم الرد علي ؟؟

أرجو طرح سؤالك أسفل فيديو الدورة لمساعدتك بشكل أفضل، وطرح الأسئلة العامة هنا، ستجد صندوق تعليقات في نهاية صفحة الدرس.

وعند رفع المشروع، نقوم بضغط مجلد المشروع من الخارج بواسطة winRAR ثم نرفع المجلد المضغوط وليس الملفات بشكل منفرد.

2023-04-14_12-50-08.thumb.png.a100ce821be50589514672f64cf2297a.png

رابط هذا التعليق
شارك على الشبكات الإجتماعية

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...