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

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

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

אנגולר 1 - Direcrive להמרת תאריך

מתוזמן נעוץ נעול הועבר תכנות
32 פוסטים 4 כותבים 2.7k צפיות
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • M מנותק
    M מנותק
    magicode
    כתב ב נערך לאחרונה על ידי
    #4
    new Date("2018-04-03T21:00:00.000Z")
    

    זה תקין לגמרי.

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

      @magicode נכון. כך עשיתי את ההמרה בסקופ. אבל הinput לא מקבל אותו. לפחות לא על ידי אנגולר. אנגולר מזהה שזה לא תאריך.

      תגובה 1 תגובה אחרונה
      0
      • zvizviZ מנותק
        zvizviZ מנותק
        zvizvi
        כתב ב נערך לאחרונה על ידי
        #6

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

        https://zvizvi.xyz

        תגובה 1 תגובה אחרונה
        1
        • zvizviZ מנותק
          zvizviZ מנותק
          zvizvi
          כתב ב נערך לאחרונה על ידי zvizvi
          #7
                ngModelCtrl.$formatters.unshift(function (a) {
                  if (ngModelCtrl.$modelValue) {
                    var date = moment(ngModelCtrl.$modelValue);
                    if (!date._isValid) {
                      return '';
                    }
                    return date.format('DD/MM/YYYY');
                  }
                });
          
                ngModelCtrl.$parsers.unshift(function (viewValue) {
                  if (viewValue && moment(viewValue, 'DD/MM/YYYY')._isValid) {
                    return moment(viewValue, 'DD/MM/YYYY').format();
                  }
                });
          
          

          https://zvizvi.xyz

          מנצפךמ תגובה 1 תגובה אחרונה
          1
          • מנצפךמ מנותק
            מנצפךמ מנותק
            מנצפך
            השיב לzvizvi ב נערך לאחרונה על ידי
            #8

            @zvizvi איפה זה אמור להיות? בתוך Directive? נא לא להתקמצן...

            zvizviZ dovidD 2 תגובות תגובה אחרונה
            0
            • zvizviZ מנותק
              zvizviZ מנותק
              zvizvi
              השיב למנצפך ב נערך לאחרונה על ידי zvizvi
              #9

              @מנצפך אמר באנגולר 1 - Direcrive להמרת תאריך:

              @zvizvi איפה זה אמור להיות? בתוך Directive?

              במקום 2 השורות האלה:

                  ngModelCtrl.$formatters.length = 0;
                  ngModelCtrl.$parsers.length = 0;
              

              https://zvizvi.xyz

              תגובה 1 תגובה אחרונה
              0
              • dovidD מנותק
                dovidD מנותק
                dovid ניהול
                השיב למנצפך ב נערך לאחרונה על ידי dovid
                #10
                פוסט זה נמחק!
                מנצפךמ תגובה 1 תגובה אחרונה
                0
                • מנצפךמ מנותק
                  מנצפךמ מנותק
                  מנצפך
                  השיב לdovid ב נערך לאחרונה על ידי
                  #11

                  @dovid אמר באנגולר 1 - Direcrive להמרת תאריך:

                  משמה

                  לא מצאתי את האשכול הקודם
                  @zvizvi ניסיתי לעשות בלי להשתמש ב moment. בינתיים לא עובד.

                   app.directive('dateFormat', function () {
                  return {
                      require: 'ngModel',
                      link: function (scope, element, attr, ngModelCtrl) {
                          ngModelCtrl.$formatters.unshift(function (a) {
                              if (ngModelCtrl.$modelValue) {
                               // var date = moment(ngModelCtrl.$modelValue);
                               // if (!date._isValid) {
                                //  return '';
                               // }
                               return new Date(ngModelCtrl.$modelValue);
                                //return date.format('DD/MM/YYYY');
                              }
                            });
                      
                            ngModelCtrl.$parsers.unshift(function (viewValue) {
                              return new Date(viewValue);
                           /*   if (viewValue && moment(viewValue, 'DD/MM/YYYY')._isValid) {
                                return moment(viewValue, 'DD/MM/YYYY').format();
                              }*/
                            });
                      }
                  };
                  

                  מה לא טוב?

                  zvizviZ dovidD 2 תגובות תגובה אחרונה
                  0
                  • zvizviZ מנותק
                    zvizviZ מנותק
                    zvizvi
                    השיב למנצפך ב נערך לאחרונה על ידי zvizvi
                    #12

                    @מנצפך אמר באנגולר 1 - Direcrive להמרת תאריך:

                    @dovid אמר באנגולר 1 - Direcrive להמרת תאריך:

                    משמה

                    לא מצאתי את האשכול הקודם
                    @zvizvi ניסיתי לעשות בלי להשתמש ב moment. בינתיים לא עובד.

                    אתה חייב לסנן החוצה ערכים שאינם תאריך, כי כשתעשה new date לערך שהוא לא תאריך - תקבל שגיאה.

                    https://zvizvi.xyz

                    מנצפךמ תגובה 1 תגובה אחרונה
                    0
                    • zvizviZ מנותק
                      zvizviZ מנותק
                      zvizvi
                      כתב ב נערך לאחרונה על ידי
                      #13

                      שים את זה בHTML ויהיה לך moment.

                      <script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.0/moment.min.js">
                      

                      https://zvizvi.xyz

                      תגובה 1 תגובה אחרונה
                      2
                      • מנצפךמ מנותק
                        מנצפךמ מנותק
                        מנצפך
                        השיב לzvizvi ב נערך לאחרונה על ידי
                        #14

                        @zvizvi מסכים איתך עקרונית. כרגע זה לא קריטי. קודם שיעבוד במה שיש תאריך.
                        משום מה הפונקציות unshift לא מופעלת בכלל. אני שם בתוכן console.log והוא לא כותב.
                        אני מריח שאני מפספס כאן משהו.

                        תגובה 1 תגובה אחרונה
                        0
                        • dovidD מנותק
                          dovidD מנותק
                          dovid ניהול
                          השיב למנצפך ב נערך לאחרונה על ידי
                          #15

                          @מנצפך אמר באנגולר 1 - Direcrive להמרת תאריך:

                          @dovid אמר באנגולר 1 - Direcrive להמרת תאריך:

                          משמה

                          לא מצאתי את האשכול הקודם

                          כשיהיה לי לך יותר כח אני יידבק ממך ויהיה לי כח לענות 🙂

                          תגובה 1 תגובה אחרונה
                          0
                          • dovidD מנותק
                            dovidD מנותק
                            dovid ניהול
                            כתב ב נערך לאחרונה על ידי
                            #16

                            זה באמת בעיה קשה שהחיפוש בפורום לא עובד, אבל באנגלית הוא עובד.

                            תגובה 1 תגובה אחרונה
                            0
                            • zvizviZ מנותק
                              zvizviZ מנותק
                              zvizvi
                              כתב ב נערך לאחרונה על ידי zvizvi
                              #17

                              @מנצפך רשמת את הדיירקטיב בmodule? מכיר את המושג?

                              https://zvizvi.xyz

                              תגובה 1 תגובה אחרונה
                              0
                              • מנצפךמ מנותק
                                מנצפךמ מנותק
                                מנצפך
                                כתב ב נערך לאחרונה על ידי מנצפך
                                #18

                                @zvizvi נראה לי שכן. הפונקציה link עובדת היטב. (ניסיתי console.log).
                                אולי תלוי בגירסה (169)

                                תגובה 1 תגובה אחרונה
                                0
                                • מנצפךמ מנותק
                                  מנצפךמ מנותק
                                  מנצפך
                                  כתב ב נערך לאחרונה על ידי מנצפך
                                  #19

                                  @zvizvi הבנתי מה הבעיה. בפתרון שלך הtype של ה input הוא text.
                                  הדגשתי כאן שאני צריך type=date.
                                  לזה זה לא מועיל (בינתיים).
                                  אני לא כ"כ יודע איך זה עובד מבחינת אנגולר, משום מה הוא לא מריץ את ה unshift.
                                  תודה @dovid בזכותך מצאתי את הפוסט הנ"ל.

                                  תגובה 1 תגובה אחרונה
                                  0
                                  • zvizviZ מנותק
                                    zvizviZ מנותק
                                    zvizvi
                                    כתב ב נערך לאחרונה על ידי
                                    #20

                                    צודק, כל זה מיועד עבור input text.
                                    ועדיין אני לא מבין למה בינדינג רגיל לתאריך שקיבלת מהשרת לא עובד.

                                    https://zvizvi.xyz

                                    מנצפךמ dovidD 2 תגובות תגובה אחרונה
                                    0
                                    • מנצפךמ מנותק
                                      מנצפךמ מנותק
                                      מנצפך
                                      השיב לzvizvi ב נערך לאחרונה על ידי מנצפך
                                      #21

                                      @zvizvi תראה פה:
                                      http://plnkr.co/edit/b2AwltcRoc21hPZp8L1n
                                      אני מנסה להציב סטרינג של תאריך בתוך input type=date.
                                      זה לא עובד. אפילו אם עושים ל date ToString זה לא עובד.

                                      תגובה 1 תגובה אחרונה
                                      0
                                      • dovidD מנותק
                                        dovidD מנותק
                                        dovid ניהול
                                        השיב לzvizvi ב נערך לאחרונה על ידי
                                        #22

                                        @zvizvi אמר באנגולר 1 - Direcrive להמרת תאריך:

                                        צודק, כל זה מיועד עבור input text.
                                        ועדיין אני לא מבין למה בינדינג רגיל לתאריך שקיבלת מהשרת לא עובד.

                                        @dovid אמר בעיצוב date ב JS + אנגולר:

                                        הבעיה זה לא הפורמט. הבעיה היא שזה מגיע מהשרת כטקסט, וזה תמיד ככה.
                                        שרת תמיד שולח טקסט, ואפילו אם זה פורמט JSON שהופך לאובייקטים, עדייi אין בJSON מושג ששמו תאריך.
                                        לכן אתה מוכרח להשתמש בפונקציה, שבל זה לא יכול להיעשות בng-model שכן זה בינדינג דו כיווני - מה יקרה כשהמשתמש ישנה את הערך? אתה חייב להחזיק עותק של המשתנה שהוא בקוד יהיה מסוג תאריך.
                                        אם אתה מוותר על הtype="data" אתה פותר את כל הבעיה, אבל כנראה תרצה להשתמש עם תוסף שיציג בורר תאריכים אחר מהמובנה של כרום (שמצריך type="date").

                                        תגובה 1 תגובה אחרונה
                                        2
                                        • dovidD מנותק
                                          dovidD מנותק
                                          dovid ניהול
                                          כתב ב נערך לאחרונה על ידי
                                          #23

                                          https://plnkr.co/edit/jx78Wu5GsFrmFKVTJZy0
                                          אבל אני חושב שהכי טוב להשתמש עם בורר תאריכים של בוטסטראפ וכדומה.

                                          מנצפךמ 2 תגובות תגובה אחרונה
                                          2

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

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

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