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

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

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

פרקטיקת התמודדות מוצלחת עם מחרוזות טקסט ארוכות

מתוזמן נעוץ נעול הועבר תכנות
19 פוסטים 5 כותבים 312 צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • yossizY מנותק
    yossizY מנותק
    yossiz
    כתב ב נערך לאחרונה על ידי
    #3

    דרך אחר לג'נרט HTML בצורה דינאמית: https://github.com/caolan/pithy
    מן הסתם יש עוד כאלה. זה מה שמצאתי בינתיים.

    📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

    תגובה 1 תגובה אחרונה
    2
    • dovidD מנותק
      dovidD מנותק
      dovid ניהול
      השיב לצדיק תמים ב נערך לאחרונה על ידי
      #4

      @צדיק-תמים התו ` הוא הדרך לזה.
      הוא "חדש" יחסית, לא נדבר על מה שהיה לפני כן...
      בשביל להשתיל פרמטרים בתוך טקסט ארוך, יש את הדרך החדשה שהיא Expression interpolation, שאתה משתיל בתוך בטקסט ביטויי JS ע"י סוגריים מסולסלות שיש לפניהם סימן דולר.
      למשל אתה יכול לכתוב פונקציה שתכיל את כל התבנית שלך:

      function GetPersonTemplate(name, age, title){
          return `
      <li class="s-sidebarwidget--item d-flex px16">
          <div class="flex--item1 fl-shrink0">
              <div class="favicon favicon-stackexchangemeta" title="${'item-' + age}">
                  ${age}
              </div>
          </div>
          <div class="flex--item wmn0 ow-break-word">
              <a href="/now-everywhere-el?cb=1" class="js-gps-track" title="New post summary">
                  ${name}
              </a>
          </div>
      </li>
      `;
      }
      

      ואח"כ לקרוא לה וככה להוסיף לפי העניין HTML נוסף וכדומה.

      מנטור אישי למתכנתים (ולא רק) – להתקדם לשלב הבא!

      בכל נושא אפשר ליצור קשר dovid@tchumim.com

      תגובה 1 תגובה אחרונה
      5
      • צדיק תמיםצ מנותק
        צדיק תמיםצ מנותק
        צדיק תמים
        השיב לyossiz ב נערך לאחרונה על ידי צדיק תמים
        #5

        @yossiz אמר בפרקטיקת התמודדות מוצלחת עם מחרוזות טקסט ארוכות:

        למה רק חלקי?

        כי לפעמים הצורך בירידת שורה מגיע בשלב שזה מבלבל, כמו למשל באמצע תגית HTML...
        לגבי mustache - לא הבנתי איך משתמשים בזה... וה-pithy לא הצלחתי למצוא CDN שלו בגוגל כדי לטעון אותו.
        המשפט תנאי שהבאת באמת נראה פתרון טוב להרבה מקרים, השאלה מה אם אני רוצה להדפיס בהתאם לערך של המשתנה, ולא משפט תנאי פשוט? מה בעצם המקבילה של switch case?
        @dovid אתה מתכוון בעצם שהפונקציה שמדפיסה רק תדפיס, ואת הטקסט שהיא תדפיס או לא - יהיה צריך לבחור בעת הקריאה אליה? אגב מעניין אותי לדעת מה באמת הגישה לגבי פיצול פונקציות והקטנתן, האם כל המרבה הרי זה משובח או שיש מקרים/רמה שזה לא מומלץ? אולי אפתח על זה נושא נפרד בהמשך...

        Don’t comment bad code — rewrite it." — Brian W. Kernighan and P. J. Plaugher"
        טיפים

        yossizY 5 2 תגובות תגובה אחרונה
        1
        • yossizY מנותק
          yossizY מנותק
          yossiz
          השיב לצדיק תמים ב נערך לאחרונה על ידי yossiz
          #6

          @צדיק-תמים אמר בפרקטיקת התמודדות מוצלחת עם מחרוזות טקסט ארוכות:

          כי לפעמים הצורך בירידת שורה מגיע בשלב שזה מבלבל, כמו למשל באמצע תגית HTML...

          תעשה ירידת שורה הרבה לפני שה"צורך מגיע". תפרמט את ה-HTML בצורה יפה. (כמו בדוגמה של @dovid)

          לגבי mustache - לא הבנתי איך משתמשים בזה...

          אולי זה באמת כדאי רק למקרים יותר מסובכים. זו עוד ספרייה ועוד שפה (לא כבדה ולא קשה, אבל בכל זאת עוד ספרייה ועוד שפה).

          השאלה מה אם אני רוצה להדפיס בהתאם לערך של המשתנה, ולא משפט תנאי פשוט? מה בעצם המקבילה של switch case

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

          לדוג':

          `content1 ${getOutputForX(X)}`
          

          📧 יוסי@מייל.קום | 🌎 בלוג | ☕ קפה

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

            @צדיק-תמים חוששני שהפתרון הכי נקי הוא לעבוד עם המתודות של JS שמשנות את הHTML, (createElement וחברותיה).
            ואפשר גם להעזר ב jQuery שמקצר את התהליכים.
            אבל בשום אופן לא לשרשר מחרוזת ארוכה של HTML

            צדיק תמיםצ dovidD 2 תגובות תגובה אחרונה
            0
            • צדיק תמיםצ מנותק
              צדיק תמיםצ מנותק
              צדיק תמים
              השיב ליוסף בן שמעון ב נערך לאחרונה על ידי
              #8

              @יוסף-בן-שמעון אמר בפרקטיקת התמודדות מוצלחת עם מחרוזות טקסט ארוכות:

              וששני שהפתרון הכי נקי הוא לעבוד עם המתודות של JS שמשנות את הHTML, (createElement וחברותיה).

              לא הבנתי איך זה עוזר? אם אני רוצה לדוגמה לשנות תוכן של אלמנט מסויים, לפי מצב ההתקדמות של הסקריפט (אני רוצה שזה גם יהיה בצבע שונה, וכן הלאה, לא מספיק לי לשנות את הטקסט בלבד)?
              אכן jQuery עשוי להועיל מאוד, אבל אני לא צריך להוסיף עוד אלמנט אלא לשנות את התוכן שלו...

              Don’t comment bad code — rewrite it." — Brian W. Kernighan and P. J. Plaugher"
              טיפים

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

                @צדיק-תמים תביא דוגמא קונקרטית שנוכל לדון עליה (יש לי דיב עם תוכן X אני רוצה למלאות אותו בY לפי תנאי Z)

                צדיק תמיםצ תגובה 1 תגובה אחרונה
                0
                • dovidD מנותק
                  dovidD מנותק
                  dovid ניהול
                  השיב ליוסף בן שמעון ב נערך לאחרונה על ידי
                  #10

                  @יוסף-בן-שמעון אמר בפרקטיקת התמודדות מוצלחת עם מחרוזות טקסט ארוכות:

                  @צדיק-תמים חוששני שהפתרון הכי נקי הוא לעבוד עם המתודות של JS שמשנות את הHTML, (createElement וחברותיה).

                  אני חושב שזה לא מעשי ליצירת תבניות של תצוגות בHTML.
                  זה טוב לאלמנט וחצי, ראה את הקוד בדוגמה שלי הוא קטן יחסית לקודים נפוצים שיש היום באיבר בודד ברשימה - item template. לטפל בזה בקוד זה גם מכוער וגם לא בר תחזוקה (אחרי הכל זה לא פרוצדורלי, זה HTML).

                  מנטור אישי למתכנתים (ולא רק) – להתקדם לשלב הבא!

                  בכל נושא אפשר ליצור קשר dovid@tchumim.com

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

                    @dovid אני חושב שתחזוקה של כזה דבר זה מאד קשה, עדיף לעשות את זה עם קצת יותר שורות ולהקל על התחזוקה
                    תשווה לקוד שלך את זה למשל

                    function GetPersonTemplate(name, age, title){
                    
                        const li = $('<li></li>')
                        li.addClass('s-sidebarwidget--item d-flex px16')
                        const ageDiv = $('<div></div>')
                        ageDiv.attr('title', title)
                        ageDiv.text(age)
                    
                        li.append(ageDiv)
                        retuen li
                    }
                    dovidD תגובה 1 תגובה אחרונה
                    0
                    • צדיק תמיםצ מנותק
                      צדיק תמיםצ מנותק
                      צדיק תמים
                      השיב ליוסף בן שמעון ב נערך לאחרונה על ידי צדיק תמים
                      #12

                      @יוסף-בן-שמעון בהתחלה אני יוצר כותרת (h2 עם id) עם תוכן התחלתי, שמשמעותו - ממתין למשתמש.
                      אחר כך כשהסקריפט מתחיל לפעול זה משתנה לתצוגת מצב נוכחי (כמובן עם עיצוב ותוכן שונים), ואז כשמסיים זה משתנה שוב להודעת סיום, ואם המשתמש לוחץ על כפתור איפוס זה משתנה חזרה למה שהיה בהתחלה.
                      כמובן שההודעת סיום לדוגמה לא קבועה, אלא משתנה לפי מה שהסקריפט עבד עליו...
                      זה דוגמה אחת, יש לי כמה כאלה בקוד...

                      Don’t comment bad code — rewrite it." — Brian W. Kernighan and P. J. Plaugher"
                      טיפים

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

                        @צדיק-תמים

                        דוגמא
                        https://jsfiddle.net/y87p6L1a/

                        תגובה 1 תגובה אחרונה
                        1
                        • dovidD מנותק
                          dovidD מנותק
                          dovid ניהול
                          השיב ליוסף בן שמעון ב נערך לאחרונה על ידי dovid
                          #14

                          @יוסף-בן-שמעון תכנותית הקוד שלך מצויין. אבל כשמגיעים לתבניות אנחנו מאוד רחוקים מהמושג תכנות, מי שכותב/כתב את הHTML לא רצה שיוסיפו קלאס פלוני ואטריביוט אלמוני, הוא רצה את הHTML המלא.. תבנית של HTML יכולה להתחיל כמה שורות ויכולה בהמשך להיות תשובת אינטרנט גדולה. זה בסוף טקסט הצהרתי קריא לבני אנוש, ולא פונקציה פרוצדוראלית.
                          כתבנית הקוד שלך הוא מבחינתי נורא... זה גם אם אני חושב שתמיד הוא יישאר במספר השורות אותו עשית (הוא לא מחזיר מה שכתבתי, צריך הרבה יותר קוד בשביל זה, במיוחד אם רוצים שזה יהיה קוד נקי).
                          זה קוד שמצריך קריאה של קוד ("שניה, מה בסוף יוצא פה") לפני כל שינוי, ועוד משתמש בjQuery.
                          תוכל לומר מה ההבדל בין מסמך HTML מלא לבין פונקציה שמחזירה פיסה קטנה?

                          מנטור אישי למתכנתים (ולא רק) – להתקדם לשלב הבא!

                          בכל נושא אפשר ליצור קשר dovid@tchumim.com

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

                            @dovid צודק, אני חוזר בי

                            תגובה 1 תגובה אחרונה
                            3
                            • צדיק תמיםצ מנותק
                              צדיק תמיםצ מנותק
                              צדיק תמים
                              כתב ב נערך לאחרונה על ידי
                              #16

                              @יוסף-בן-שמעון לפחות ככה זכיתי בדרך אגב להכיר את התגית
                              <progress>... 😉
                              קודם חשבתי לתומי שמוכרחים בשביל כזה דבר להשתמש בספריות דוגמת זו...

                              Don’t comment bad code — rewrite it." — Brian W. Kernighan and P. J. Plaugher"
                              טיפים

                              י תגובה 1 תגובה אחרונה
                              2
                              • י מנותק
                                י מנותק
                                יוסף בן שמעון
                                השיב לצדיק תמים ב נערך לאחרונה על ידי
                                #17

                                @צדיק-תמים אמר בפרקטיקת התמודדות מוצלחת עם מחרוזות טקסט ארוכות:

                                קודם חשבתי לתומי שמוכרחים בשביל כזה דבר להשתמש בספריות דוגמת זו...

                                כמובן שיש יתרון עיצובי לספריות האלו, התג פרוגרס מאד בנאלי

                                צדיק תמיםצ תגובה 1 תגובה אחרונה
                                1
                                • צדיק תמיםצ מנותק
                                  צדיק תמיםצ מנותק
                                  צדיק תמים
                                  השיב ליוסף בן שמעון ב נערך לאחרונה על ידי
                                  #18

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

                                  Don’t comment bad code — rewrite it." — Brian W. Kernighan and P. J. Plaugher"
                                  טיפים

                                  תגובה 1 תגובה אחרונה
                                  2
                                  • 5 מנותק
                                    5 מנותק
                                    5566brs
                                    השיב לצדיק תמים ב נערך לאחרונה על ידי
                                    #19

                                    @צדיק-תמים אמר בפרקטיקת התמודדות מוצלחת עם מחרוזות טקסט ארוכות:

                                    ה-pithy לא הצלחתי למצוא CDN שלו בגוגל כדי לטעון אותו.

                                    https://cdn.jsdelivr.net/gh/caolan/pithy@latest/lib/pithy.min.js

                                    תגובה 1 תגובה אחרונה
                                    1

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

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

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