דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. ניקוי אובייקט js

ניקוי אובייקט js

מתוזמן נעוץ נעול הועבר תכנות
8 פוסטים 4 כותבים 178 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • chagoldC מנותק
    chagoldC מנותק
    chagold
    כתב ב נערך לאחרונה על ידי chagold
    #1

    אני רוצה לעשות JSON.stringify על אובייקט, ואני מקבל TypeError: Converting circular structure to JSON.

    אני צריך לנקות את האובייקט מהפונקציות שלו, וראיתי כאן,
    אבל הסתבכתי כיון שלא הצלחתי לעשות העתקה עמוקה לאובייקטים.

    איך מומלץ לעשות? תודה רבה.

    י תגובה 1 תגובה אחרונה
    0
    • chagoldC chagold מחק נושא זה ב
    • chagoldC chagold שחזר נושא זה ב
    • י מנותק
      י מנותק
      יוסף בן שמעון
      השיב לchagold ב נערך לאחרונה על ידי
      #2

      @chagold תוכל יותר להסביר את הסיטואציה? האם באמת יש הפניות מעגליות באובייקט? ולמה אתה צריך לנקות את האובייקט מהפונקציות? ואיך זה קשור להעתקה עמוקה?

      chagoldC תגובה 1 תגובה אחרונה
      0
      • chagoldC מנותק
        chagoldC מנותק
        chagold
        השיב ליוסף בן שמעון ב נערך לאחרונה על ידי chagold
        #3

        @יוסף-בן-שמעון מבוטל.
        גיליתי את הטעות שלי.
        תודה רבה.

        chagoldC תגובה 1 תגובה אחרונה
        0
        • chagoldC מנותק
          chagoldC מנותק
          chagold
          השיב לchagold ב נערך לאחרונה על ידי chagold
          #4

          אחרי מחשבה ובדיקה חוזרת.
          אע"ג שהיה לי איזה פיתרון, אבל אני סבור שהוא לא תקין, כיון שכשאני עושה הדפסה בקונסול של איזה ערך אני רואה שיש לופ ענק שמתגלגל שם, וזה לא אמור להיות לפי הערכתי. אני מציג את הדברים.

          זה ב-vueX.
          אני רוצה לשנות ערך שנמצא בstate.user (state.user.accountselected). (הערך הנוסף הוא 'administrator')

          יצרתי 'מוטציה' חדשה

          selectaccount(state,account) {
                  state.user.accountselected = account
          	localStorage.setItem('user', JSON.stringify(state.user));
          }
          

          וכשאני קורא אליה, השגיאה היא כדלעיל. זה הלוג.

          6556140a-aafd-45f7-9a7a-f5b992534d07-image.png

          י תגובה 1 תגובה אחרונה
          0
          • י מנותק
            י מנותק
            יוסף בן שמעון
            השיב לchagold ב נערך לאחרונה על ידי
            #5

            @chagold לא מבין בVUE, השגיאה הזו אומרת שיש הפניה מעגלית, כלומר אחד מהנכסים של האובייקט מצביע לאובייקט עצמו, לדוגמא

            const obj = {}
            obj.prop = obj
            

            נסה לדמיין איך אפשר להמיר כזה דבר למחרוזת.

            ספציפית אצלך זה נראה שהארגומנט account מצביע על ה state.user, וזה גורם הפניה מעגלית כאשר אתה יוצר נכס בשם accountselected ומצביע איתו על היוזר.

            היות ולא הבנתי את הצורך שלך, אין לי פיתרון, רק מציג את הבעיה

            chagoldC תגובה 1 תגובה אחרונה
            2
            • א מנותק
              א מנותק
              ארכיטקט
              כתב ב נערך לאחרונה על ידי
              #6

              אני אוהב להשתמש בזה
              https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#tojson_behavior
              כמובן מותנה בזה שהאובייקט שלך הוא באמת אובייקט (בטייפסקריפט יש בזה קפידא יתירה)

              אידיאולוגיות גדולות נכנסות למטחנה של עולם המעשה ויוצאות ממנו בפירורים (ווינסטון צ'רצ'יל, סתם סתם, זה שלי)

              תגובה 1 תגובה אחרונה
              1
              • chagoldC מנותק
                chagoldC מנותק
                chagold
                השיב ליוסף בן שמעון ב נערך לאחרונה על ידי
                #7

                @יוסף-בן-שמעון
                מצאתי בס"ד את הפתרון.
                זה 2 בעיות שונות.

                1. בשביל ההפניה המעגלית, צריך בפוקנציה שבקומפוננט שקורא (למוטציה), לשכפל את האובייקט
                selectaccount:function (payload) {
                	const { account } = payload;
                	this.$store.commit("selectaccount",account);
                }
                
                1. ובשביל שלא יהיה לופ ענק סתם, צריך במוטציה להתנות שלא יהיה undefined. (ההסבר כנראה - כי משום מה - כשאין לו ערך (כגון כשהוא מאתחל את הפרוייקט) הוא מריץ את כל האובייקט של vue😲 או משהו דומה, מה שלא קורא כשאני בודק שהוא לא undefined).
                S תגובה 1 תגובה אחרונה
                1
                • S מנותק
                  S מנותק
                  Shaya
                  השיב לchagold ב נערך לאחרונה על ידי
                  #8

                  @chagold אמר בניקוי אובייקט js:

                  בשביל ההפניה המעגלית, צריך בפוקנציה שבקומפוננט שקורא (למוטציה), לשכפל את האובייקט

                                                                                                                                              selectaccount:function (payload) {                                                                                                                                                                            	const { account } = payload;                                                                                                                                                                            	this.$store.commit("selectaccount",account);                                                                                                                                                                            }
                  

                  @chagold, הערה בדרך אגב (לא חושב שזה מצדיק נושא חדש):
                  אפשר לעשות destructuring על הארגומנט עצמו, ובכך לחסוך שורה מיותרת:

                  selectaccount:function ({ account }) {
                    this.$store.commit("selectaccount",account);
                  }
                  
                  תגובה 1 תגובה אחרונה
                  4

                  בא תתחבר לדף היומי!
                  • התחברות

                  • אין לך חשבון עדיין? הרשמה

                  • התחברו או הירשמו כדי לחפש.
                  • פוסט ראשון
                    פוסט אחרון
                  0
                  • דף הבית
                  • קטגוריות
                  • פוסטים אחרונים
                  • משתמשים
                  • חיפוש
                  • חוקי הפורום