הבעיה היא לא הgoto
-
הנה דוגמא בnodejs
$ node contact.js a # The Above command lauches a prompt ? Enter firstname .. John ? Enter lastname .. Doe ? Enter phone number .. +145**** ? Enter email address .. john.doe@contacto.com New contact added
הכל אוטומטי וגנרי בזכות ספריות מתאימות, זה ההגדרה:
const questions = [ { type : 'input', name : 'firstname', message : 'Enter firstname ..' }, { type : 'input', name : 'lastname', message : 'Enter lastname ..' }, { type : 'input', name : 'phone', message : 'Enter phone number ..' }, { type : 'input', name : 'email', message : 'Enter email address ..' }
זה הקוד! :
prompt(questions).then((answers) => addContact(answers));
-
@dovid אמר בהבעיה היא לא הgoto:
הנה דוגמא בnodejs
א. איך חוזרים שלב בודד אחורה? ולאחר מכן ממשיכים לקבל את הנתון הבא מחדש (למרות שכבר התקבל פעם אחת).
ב. יש לי תנאי, שאם הוא בחר למשל סטטוס אישי = תלמיד ישיבה, אני אצטרך ג"כ לבקש ממנו שיזין את קוד הישיבה, ואחרת אין צורך לדרוש נתון זה.
איך מתמודדים עם זה? -
@nigun לא נראה לי שזה אמור להיות מורכב, קח פונקציה כזו
function buildQuestions (questions) { var answers = {}; for (var i = 0; i < questions.length; i++) { var question = questions[i]; var input = read(question); answers[question.name] = input; } return answers; } function read (question) { var input = readAGI(question.massage, question.type); if (!input && question.isRequired && question.tryAgain) { --question.tryAgain; return read(question); } return input; }
ותעביר לה גייסון כמו שדוד הציע, תוסיף לגייסון שדות כמו isRequired tryAgain ויש לך קוד שיתאים לכל השיחות
-
צורת הדברים כבר נידונה והתבשלה כאן
https://tchumim.com/post/59303
ועדיין אין לי פיתרון לשלוחה שאמורה להיות עם תפריטים ותפריטי משנה וכו'.
אציין שלכן אני עדיין לא עברתי לצורת העבודה של מערך נתונים נדרשים, כי לרוב אני מתחיל עם תפריטים וכו, ורק בשלב כלשהוא יש לי למשל רישום שאני עובד כעת לקבל רשימת נתונים בזה אחר זה.
ולכן יותר נוח לי לעבוד על ידי שאני דורש נתון נתון ומבצע פקודות לפי הנתון שקיבלתי -
@חוקר שקול כתיבה בצורה כזו
const questions = { firstname: { type: 'input', name: 'firstname', message: 'Enter firstname ..', nextStep () { if(answers.talmid) return this.yeshivaCode; else return this.otherStep } } }
אפשר לשכלל את זה ולעבוד עם שני סוגי מחלקות, מחלקת Menu ומחלקת Question, כל תפריט יכיל מערך של שאלות, וה nextStep או שיחזיר את השאלה הבאה או מופע של תת תפריט.
ואל תאמר מה לי ולצרה זו, ההשקעה שווה. לא לחינם דוד התחלחל למראה הקוד הפרוצדורלי, קשה לי להבין איך מתחזקים כזה קוד, קוד כזה עם תתי תפריטים הופך להיות בלתי אפשרי לתחזוקה, אם תעבוד מונחה עצמים אני בטוח שתרגיש את ההבדל -
@יוסף-בן-שמעון
הקושי שלי הוא כזה, ליצור בתחילת הקוד אובייקט עם כל סוגי הסיטואציות שאולי יהיו בדף בתת תפריט של תת תפריט, והכל יככב לי בראש הקוד, הוא מאוד מאוד מסורבל, ויזיק יותר משיועיל, כי אני חייב לראות מול העיניים בכל שלב את השלב שלפניו.
דוגמא פשוטה לבעיה, אחד הערכים שאני משתמש הוא איזה ספרות לאפשר למאזין להקיש בתפריט/השאלה הנוכחית, ואם עשיתי תפריט שבתחילת כתיבת הקוד חשבתי לתת לו לבחור את האפשרויות 1258 בלבד, ולאחר כתיבת הקוד אני מחליט להוסיף את אפשרות 7 לתפריט, אז אני מוסיף תנאי באם ההקשה שווה 7 מה לבצע, אך אני חייב לזכור להוסיף למקשים המותרים את 7 וס"ה יהיה 12578, וכן לשנות בהודעת התפריט את החלק הנוסף.
אם המערך יהיה למעלה, אני יסתובב הלוך ושוב ואני ישאיר חלקים לעדכון אח"כ ואני ישכח וכו'.
אם אני רואה לפני כל שלב את השלב שלפניו אני יזכור יותר טוב ויוכל ביותר גמישות להוסיף שלבים וכו'.
לכן אני חשבתי לעשות כך:
יהיה לי בתחילת הקוד אובייקט ריק שאני יגדיר שבכל פעם שאני קורא לפונקציית read זה יאכלס לאובייקט (אם לא קיים) את ההגדרות ושם הערך הנוכחי, ואז אני חוזר לנקודה שיש לי אובייקט של ההגדרות, ומאידך אני בונה אותו לפי התקדמות הקוד והתפריטים.
וכעת אוכל כבר להוסיף בהגדרות ערך בשם first ששם אוכל לכתוב את שם השלב הקודם, ואז בהקשה על המקש הייעודי נניח כוכבית הפונקציה תדרוש מחדש את הקשת הערך הקודם, לפי ההגדרות המאוכלסות באובייקט. -
@dovid קראתי שוב את דבריך בעיון, אכן אתמול מיהרתי והבנתי בטעות שהתכוונת לגוטו ועל זה הגבתי שלא הבנתי את דבריי. מתברר שזה אני שלא הבנתי אותך.. (אל תתלהב, אני לא אתחיל לסמוך עליך מעכשיו בעיניים עצומות אבל קצת יותר...)
כפי שכתבתי, בעבר ניסיתי להעביר את תהליך קליטת הנתונים מהמשתמש למונחה עצמים, וזה גרם לבעיות שונות, אבל באמת זה יחסוך עבודה וכדאי שארענן את זה. אשתדל לעדכן, אולי זה יעזור לאחרים@WWW וכל האחרים מפורום אסטריסק, אשמח שתראו לי איך הייתם ניגשים למשימה הזו. אם יש לכם סבלנות תקחו כמה דקות ונשווה תוצאות.
-
@חוקר
אולי אפשר את התפריט כעץ של מערכים
ולהכניס את הספרות להקשה בצאצאים של המערך
דהיינו בתפריט היעד
ואז הוא יעשה לולאה שמחפשת את תפריט המתאים
למשל אם הקיש 3 וימצא צאצא עם alise 3-5 אז הוא יעבור לתפריט הנ"ל
אפשר גם 3,4,5 וכדומה
אפשר גם להשתמש בregexclienttype: { type: 'input', name: 'clienttype', message: 'Enter firstname ..', acte:{ yeshivaCode:{ type: 'input', alise: '1-2', message: 'Enter Code ..', } }ColleCode:{ type: 'input', alise: '3-4', message: 'Enter Code ..', }
יתכן מאוד שאני סתם מקשקש
אבל אני מנסה לעזור בכל זאת -
@nigun
אני חוזר ואומר את הנקודה.
אני לא חושב שנכון מצידי לעבוד עם מערך בראש הקוד.
יש לי המון פעולות לביצוע בין לבין.
למשל בהקשת תאריך, אני מעבד את התאריך שהמאזין הקיש בפורמט 18052020 לאובייקט תאריך שממנו אני מקבל מחרוזת בשם 20200518 שהשאלה הבאה בתור משמיעה נתון מתיקיה ששמה כשם התאריך שהוקש בפורמט המעובד, אז אני לא יכול לקבוע זאת בראש הדף.
אני חייב שהקוד יהיה סיפור ויובן בכל שלב מה השלב הקודם והשלבהבא -
@nigun אמר בהבעיה היא לא הgoto:
@חוקר
אז תוסיף אובייקט במערך שמכיל פונקציה
שתעבד את הנתוניםאת הסיפור אבל הוא לא יספר.
אתה צודק שדברים קבועים ניתן להכניס ישירות הגדרה שאני רוצה שיחזיר לי את הנתון בפורמט תאריך המבוקש.
אבל כל העבודה והרעיון והאתגר לטעמי בפיתוח מערכות טלפוניות הוא שבקוד עצמו אתה רואה שלב אחר שלב את מה שמושמע בטלפון.
לא שבראש הדף יש לי רמזים על כל מיני תרחישים -
@חוקר אתה טועה במטרה.
אתה מחפש שיהיה קל להבין את הזרימה, זה באמת אתגר מעניין וצריך להקדיש לזה מחשבה.
אנחנו מחפשים שלא תכתוב קוד לאימות של מספר מעל X, קוד למעבר לשתי שלבים אחורה וכו' כשכל זה ניתן להצהרה בצורה מתומצתת וקלה לתחזוקה.
אני לא מבין למה אתה מתייחס ב"ראש הדף", אנחנו מדברים אפילו על מידע שיכול להיות בקובץ או במסד נתונים שלפיו כל השיחה תתבצע.