Issue
I'm trying to write a rock, paper, scissors game in angular and I can't seem to get the onclick method of play to work.
I've heard it was a scoping problem but cant seem to understand/apply that in what i have written.
Here is my html code
<button class="play rock" type="button" onclick="play('rock')"></button>
Here is my ts script
import { Component, OnInit } from '@angular/core';
@Component({
  selector: 'app-rps-game',
  templateUrl: './rps-game.component.html',
  styleUrls: ['./rps-game.component.scss']
})
export class RpsGameComponent implements OnInit {
  loses: number;
  wins: number;
  constructor() { }
  ngOnInit() {
  }
  play(userChoice: string) {
    document.getElementById('player').innerHTML = '';
    document.getElementById('opponent').innerHTML = '';
    document.getElementById('results').innerHTML = '';
    const computerChoicer = Math.random();
    let computerChoice = '';
    if (computerChoicer < 0.34) {
      computerChoice = 'rock';
    } else if (computerChoicer <= 0.67) {
      computerChoice = 'paper';
    } else {
      computerChoice = 'scissors';
    }
    const winner = this.compare(userChoice, computerChoice);
    document.getElementById('results').innerHTML = winner;
    document.getElementById('wins').innerHTML = String(this.wins);
    document.getElementById('loses').innerHTML = String(this.loses);
  }
  compare(choice1, choice2) {
    if (choice1 === choice2) {
      return 'The result is a tie!';
    } else if (choice1 === 'rock') {
      if (choice2 === 'scissors') {
        this.wins++;
        return 'rock wins. rock on.';
      } else {
        this.loses++;
        return 'sorry. paper wins.';
      }
    } else if (choice1 === 'paper') {
      if (choice2 === 'rock') {
        this.wins++;
        return 'paper wins';
      } else {
        this.loses++;
        return 'sorry. scissors win.';
      }
    } else if (choice1 === 'scissors') {
      if (choice2 === 'rock') {
        this.loses++;
        return 'sorry. rock wins';
      } else {
        this.wins++;
        return 'scissors win';
      }
    }
  }
}
Uncaught ReferenceError: play is not defined at HTMLButtonElement.onclick ((index):1)
Solution
onclick="play('rock') is not something that Angular knows about.  use (click)="play('rock')" instead
<button class="play rock" type="button" (click)="play('rock')"></button>
You might want to read up on angular a bit more: https://angular.io/guide/component-interaction
Basically though:
- Square bracket bindings like <button [title]="myTitle">are an INPUT binding, and it will bind themyTitleproperty on your class to thetitleHTML attribute. This is a one-way binding and themyTitleproperty cannot be updated from the button.
- Parenthesis bindngs like <button (click)="someFn()">are an OUTPUT binding and will (in this case) run thesomeFn()function when theclickeven occurs.
These two can also be combined for two-way bindings on some components, but they need to be built in a special way to handle this.
Answered By - FiniteLooper
 
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.