Почему не работает метод в JavaScript? [дубликат]

140
09 ноября 2019, 12:20

На данный вопрос уже ответили:

  • Потеря контекста вызова 5 ответов

Когда я в консоли использую ранее созданные в самом HTML-файле методы moveRight или moveDown, то они работают как надо, а вот moveLeft и moveUp, не работают. Консоль возвращает not a function. Хотя я уже всё копировал под чистую с учебника. По учебнику вводя в консоли tesla.moveUp(); элемент должен двигаться вверх, но этого не происходит.

var Car = function (x, y) { 
  this.x = x; 
  this.y = y; 
}; 
Car.prototype.draw = function () { 
  var carHtml = '<img src="http://nostarch.com/images/car.png">'; 
  this.carElement = $(carHtml); 
  this.carElement.css({ 
    position: "absolute", 
    left: this.x, 
    top: this.y 
  }); 
  $("body").append(this.carElement); 
}; 
 
Car.prototype.moveRight = function() { 
  this.x += 5; 
  this.carElement.css({ 
    left:this.x, 
    top:this.y 
  }); 
}; 
 
Car.prototype.moveDown = function() { 
  this.y += 5; 
  this.carElement.css({ 
    left:this.x, 
    top:this.y 
  }); 
}; 
 
Car.prototype.moveLeft = function () { 
  this.x -= 5; 
  this.carElement.css({ 
    left: this.x, 
    top: this.y 
  }); 
}; 
Car.prototype.moveUp = function() { 
  this.y -= 5; 
  this.carElement.css({ 
    left:this.x, 
    top:this.y 
  }); 
}; 
 
var tesla = new Car(20, 20); 
var nissan = new Car(100, 200); 
tesla.draw(); 
nissan.draw();
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

Answer 1

var Car = function (x, y) { 
  this.x = x; 
  this.y = y; 
}; 
Car.prototype.draw = function () { 
  var carHtml = '<img src="http://nostarch.com/images/car.png">'; 
  this.carElement = $(carHtml); 
  this.carElement.css({ 
    position: "absolute", 
    left: this.x, 
    top: this.y 
  }); 
  $("body").append(this.carElement); 
}; 
 
Car.prototype.moveRight = function() { 
  this.x += 5; 
  this.carElement.css({ 
    left:this.x, 
    top:this.y 
  }); 
}; 
 
Car.prototype.moveDown = function() { 
  this.y += 5; 
  this.carElement.css({ 
    left:this.x, 
    top:this.y 
  }); 
}; 
 
Car.prototype.moveLeft = function () { 
  this.x -= 5; 
  this.carElement.css({ 
    left: this.x, 
    top: this.y 
  }); 
}; 
Car.prototype.moveUp = function() { 
  this.y -= 5; 
  this.carElement.css({ 
    left:this.x, 
    top:this.y 
  }); 
}; 
 
var tesla = new Car(200, 20); 
var nissan = new Car(100, 200); 
tesla.draw(); 
nissan.draw();
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> 
<div> 
  <button onclick="tesla.moveLeft()">Left</button> 
  <button onclick="tesla.moveRight()">Right</button> 
  <button onclick="tesla.moveUp()">Up</button> 
  <button onclick="tesla.moveDown()">Down</button> 
  <br/> 
  <br/> 
</div>

READ ALSO
Front End, Back End, Website. Прослушивание музыки на сайте

Front End, Back End, Website. Прослушивание музыки на сайте

Подскажите, как можно добавить на музыкальный сайт прослушивание музыки таким образом, что бы при нажатии на песню открывалась либо новая...

165
Возможно ли сохранять в localStorage динамически добавляемые input, а после перезагрузки страницы возвращать их вместе с value?

Возможно ли сохранять в localStorage динамически добавляемые input, а после перезагрузки страницы возвращать их вместе с value?

Представьте, что есть плюс нажимая на который вставляется inputТаких input можно вставить сколько угодно (пусть будет 30 штук)

136