Неизвестная проблема с доступом к получателю / установщику;Сообщение об ошибке: «TypeError: Невозможно прочитать свойство« push »из неопределенного в Object.addDishToCourse» - PullRequest
0 голосов
/ 27 апреля 2019

Проблема в том, что в небольшом коде есть неизвестная ошибка.Метод / функция для получения набора курсов, которые являются свойствами свойства курсов.Массивы предметов обеда для еды.Это должна быть небольшая синтаксическая ошибка, но я не могу на всю жизнь найти чертову штуку.Я подумал, что выкину его туда и посмотрю, сможет ли кто-нибудь найти небольшую ошибку.:)

Я проверил код, когда строка за строкой выявлял опечатки или опечатки с именами переменных и т. Д. В notepad ++, и провел некоторый поиск в Google, задавая вопросы на форумах CodeAcademy и просматривая материалы курса, чтобы узнать, есть ли какой-либо элемент.Я скучаю.Я проверил установку свойств, чтобы они не были частными переменными, но я все еще вижу сообщение об ошибке.Это должно быть что-то простое, что кто-то более опытный увидит сразу.Код в основном почти идентичен видео решения.Поэтому я просто сократил свое решение для видео, но все еще получаю это сообщение об ошибке.

Ошибка: TypeError: Невозможно прочитать свойство 'push' из undefined в Object.addDishToCourse

const menu = {

  //Our restaurants great select of food
  _courses: {
    appetizers: [],
    mains: [],
    desserts: [],
},

//warm up the appetite!!!!!
get appetizers(){
 return this._courses.appetizers; 
},

set appetizers(appetizers){
    this._courses.appetizers = appetizers;
 },

//The main course baby!!!!
get mains(){
 return this._courses.mains;  
},

set mains(mains){
   this._courses.mains = mains;
 },

//Save room for dessert!!!!!
get desserts(){
 return this._courses.desserts; 
},

 set desserts(desserts){
   this._courses.desserts = desserts;
 },

//Get Method to access the list of great appetizers, main dishes, and desserts to choose from :)
get courses() {
      return {
         appetizers: this._courses.appetizers,
         mains: this._courses.mains,
         desserts: this._courses.desserts
   };
},

  /*  error was here ????
get courses() {
      return {
         appetizers: this.appetizers,
         mains: this.mains,
         desserts: this.desserts
   };
}, */ 

// Sets a dish to a course object. What fun is it to have more selections  on the menu!!
addDishToCourse(courseName, dishName, dishPrice){
    const dish = {
      name: dishName,
      price: dishPrice,
    };
  //doesn't work at this point
     this._courses[courseName].push(dish)
   },   

//Generates a random dish from a course's list of exciting options
getRandomDishFromCourse(courseName){
    const dishes = this._courses[courseName];
    const index = Math.floor(Math.random()*dishes.length);
    return dishes [index];  
}, 

//Creates an random meal and generates a price of the said meal
generateRandomMeal(){
    const appetizer =this.getRandomDishFromCourse('appetizers');
    const main = this.getRandomDishFromCourse('mains');
    const dessert = this.getRandomDishFromCourse('desserts');
    const totalprice = appetizer[price]+main[price]+dessert[price];
    return console.log(`Your appetizer is ${appetizer.name}, your main dish is ${main.name}, and your dessert is ${dessert.name}. The total price of your meal is ${totalprice}.`);
  }, 
};

//What's our menu going to be. Let's add some selections.
menu.addDishToCourse('mains','pizza',2.00);
console.log(menu.addDishToCourse('mains','pizza',2.00));
menu.addDishToCourse('mains','salmon',4.00);
menu.addDishToCourse('mains','burger',1.50);
menu.addDishToCourse('appetizers','salad',1.00);
menu.addDishToCourse('appetizers','snails',1.00);
menu.addDishToCourse('appetizers','mushroom soup',1.00);
menu.addDishToCourse('dessert','fruit salad',0.50);
menu.addDishToCourse('dessert','orange serbert',2.00);
menu.addDishToCourse('dessert','vanilla ice cream',3.00);

const meal = menu.generateRandomMeal();
console.log(meal);
...