לולאה שנתקעת ומדלגת פריטים
-
@yossiz
אני מעדכן שני רשימות. אז אני שם את זה אחרי השני הם אכן ממתינים אחד לשני? אני חושב ששוב לא הבנתי.await Promise.all(dard.map(item => { return wixData.get('card', item._id) .then((item2) => { console.log(item2); item2.print = 'הודפס'; return wixData.update('card', item2).catch(err => err) }) .catch((err) => { const errorMsg = err; }); })) await Promise.all(anashim.map(item4 => { return wixData.get('tormim', item4._id) .then((item6) => { console.log(item6); item6.print = 'הודפס'; return wixData.update('tormim', item6).catch(err => err) }) .catch((err) => { const errorMsg = err; }); })) .then(() => { console.log("הסתיים"); })
-
@אבי-203 הבנת טוב. הם אכן ממתינים אחד לשני.
יש לי עדיין כמה וכמה הצעות שיפור לקוד שלך:- לכאורה תוכל גם לעדכן את שתי הרשימות במקביל, אם אין תלויות בין אחד לשני.
- כדאי להשתמש במשתנים עם שמות תיאוריים, משתמש שהוא מערך, תן לו שם בלשון רבים. משתנה שהוא אובייקט מסוג
card
תקרא לוcard
ולא רקitem
סתמי, וכו' על זה הדרך. כן, אם יש כמה משתנים מסוגcard
אל תקרא להםcard1
,card2
אלא תן להם שמות לפי השימוש שלהם בקוד - לדוגמהnewCard
,updatedCard
וכן על זה הדרך. לא כדאי להשתמש בראשי תיבות, לא עולה כסף לכתוב במילואו. - יש שתי דרכים להתנהל עם פרומיסים: הדרך הישנה: שימוש ב-API של הפרומיסים, כלומר:
then
ו-catch
. הדרך החדשה: שמוש במילות המפתח -async
ו-await
.
(לדעתי) מומלץ להיות עקבי בצורת ההתנהלות ולא לקפוץ בין אחד לשני כל הזמן.
יש אומנם מקומות שבהם אין מנוס מלהשתמש ב-API של הפרומיסים, לדוגמה: אין תחליף לפונקציית Promise.all בתחביר ה-async/await
-י. ובמקרים אלו ההכרח לא יגונה. - אם הקוד שמעדכן את רשימת ה-
anashim
זהה לקוד שמעדכן את ה-cards
, ניתן לצרף אותם יחד לפונקציה ג'נרית לעדכון רשימה. - אאל"ט, אין צורך למשוך את האובייקט שוב מה-DB של WIX כדי לעדכן אותו, ניתן להשתמש באובייקט מהרשימה.
על פי כל הנ"ל, הייתי משכתב את הקוד שלך כך:
function updateItemPrinted (table, item) { item.print = 'הודפס'; return wixData.update(table, item); } await Promise.all([ ...cards.map((card) => updateItemPrinted('card', card)), ...anashim.map(torem => updateItemPrinted('tormim', torem)) ]); console.log('הסתיים');
קצר וקולע.
יפה, לא? -
@yossiz לא אתן לך על האחרונה לייק...
אבל עדין חסר לי.
אני מריץ את הלולאה על אובייקטים (anashim,dard) שנבנים בפונקצייה אחרת בפעולת ההורדה של הPDF.
ואז הפונקצייה הזו אמורה לעדכן במסד הנתונים לא באובייקט, למסד הנתונים קוראים tormim , card/וממה שכתבת נראה שהעדכון הוא באובייקט לא במסד הנתונים. אני טועה? או שמה שצבוע באדום זה ההדמייה שלך לשם מסד הנתונים
updateItemPrinted('card', card)),