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

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

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

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

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

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

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

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

    י תגובה 1 תגובה אחרונה
    0
    • chagoldC chagold מחק נושא זה ב
    • chagoldC chagold שחזר נושא זה ב
    • chagoldC chagold

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

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

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

      י מנותק
      י מנותק
      יוסף בן שמעון
      כתב ב נערך לאחרונה על ידי
      #2

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

      chagoldC תגובה 1 תגובה אחרונה
      0
      • י יוסף בן שמעון

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

        chagoldC מנותק
        chagoldC מנותק
        chagold
        כתב ב נערך לאחרונה על ידי chagold
        #3

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

        chagoldC תגובה 1 תגובה אחרונה
        0
        • chagoldC chagold

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

          chagoldC מנותק
          chagoldC מנותק
          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
          • chagoldC chagold

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

            זה ב-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

            י מנותק
            י מנותק
            יוסף בן שמעון
            כתב ב נערך לאחרונה על ידי
            #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
              • י יוסף בן שמעון

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

                const obj = {}
                obj.prop = obj
                

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

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

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

                chagoldC מנותק
                chagoldC מנותק
                chagold
                כתב ב נערך לאחרונה על ידי
                #7

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

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

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

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