为什么当用户单击按钮时我的标签没有更新?
我似乎看不出我的条件语句中缺少什么。单击页面上的按钮时,textContent
不会更新。
const btn1 = document.querySelector('.btn1');
const btn2 = document.querySelector('.btn2');
const btn3 = document.querySelector('.btn3');
const playerChoice = [btn1, btn2, btn3];
const computerChoice = ['Lapis','Payrus','Scalpellus']
// Game options rock[0] , paper[1] , scissors[2]
// Lapis, Papyrus, Scalpellus;
const startGame = () => {
playerChoice.forEach(options => {
options.addEventListener('click', function(){
const rantInt = Math.floor(Math.random() * 3);
const pcOptions = computerChoice[rantInt];
//Callback to compare choices
compareChoices(this.innerHTML, pcOptions);
});
});
};
startGame();
const compareChoices = (player, computer) => {
const result = document.querySelector('.winner');
if ( player === computer) {
result.textContent = 'TIE'
}
else if (player == 'Lapis' && computer == 'Scalpellus') {
result.textContent = 'Player won! Lapis beats Scalpellus.';
}
else if (computer == 'Lapis' && player == 'Scalpellus') {
result.textContent = 'Computer won! Lapis beats Scalpellus';
}
else {
return;
}
};
text-align: {
center;
}
h2 {
margin: 60px;
text-align: center;
}
.button {
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #E44949;
}
.btn1 {
margin: 25px;
width: 70px;
height: 30px;
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #FA9696;
}
.btn2 {
margin: 25px;
width: 70px;
height: 30px;
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #FA9696;
}
.btn3 {
margin: 25px;
width: 80px;
height: 30px;
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #FA9696;
color: black;
}
<style>
@import url('https://fonts.googleapis.com/css2?family=Londrina+Shadow&family=Rubik:ital,wght@1,300&display=swap');
</style>
<h1>Let's play! Click on the buttons.</h1>
<h1>
<button class="btn1">Lapis</button>
<button class="btn2">Papyrus</button>
<button class="btn3">Scalpellus</button>
</h1>
<h2 class="winner"></h2>
<script src="script.js"></script>
</body>
</html>
I can't seem to see what I'm missing in my conditional statements. When the button's are clicked on the page the textContent
isn't updating.
const btn1 = document.querySelector('.btn1');
const btn2 = document.querySelector('.btn2');
const btn3 = document.querySelector('.btn3');
const playerChoice = [btn1, btn2, btn3];
const computerChoice = ['Lapis','Payrus','Scalpellus']
// Game options rock[0] , paper[1] , scissors[2]
// Lapis, Papyrus, Scalpellus;
const startGame = () => {
playerChoice.forEach(options => {
options.addEventListener('click', function(){
const rantInt = Math.floor(Math.random() * 3);
const pcOptions = computerChoice[rantInt];
//Callback to compare choices
compareChoices(this.innerHTML, pcOptions);
});
});
};
startGame();
const compareChoices = (player, computer) => {
const result = document.querySelector('.winner');
if ( player === computer) {
result.textContent = 'TIE'
}
else if (player == 'Lapis' && computer == 'Scalpellus') {
result.textContent = 'Player won! Lapis beats Scalpellus.';
}
else if (computer == 'Lapis' && player == 'Scalpellus') {
result.textContent = 'Computer won! Lapis beats Scalpellus';
}
else {
return;
}
};
text-align: {
center;
}
h2 {
margin: 60px;
text-align: center;
}
.button {
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #E44949;
}
.btn1 {
margin: 25px;
width: 70px;
height: 30px;
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #FA9696;
}
.btn2 {
margin: 25px;
width: 70px;
height: 30px;
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #FA9696;
}
.btn3 {
margin: 25px;
width: 80px;
height: 30px;
text-align: center;
font-family: 'Rubik', sans-serif;
background-color: #FA9696;
color: black;
}
<style>
@import url('https://fonts.googleapis.com/css2?family=Londrina+Shadow&family=Rubik:ital,wght@1,300&display=swap');
</style>
<h1>Let's play! Click on the buttons.</h1>
<h1>
<button class="btn1">Lapis</button>
<button class="btn2">Papyrus</button>
<button class="btn3">Scalpellus</button>
</h1>
<h2 class="winner"></h2>
<script src="script.js"></script>
</body>
</html>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
箭头函数更改
this
的值。要使
this
引用元素(按钮),请使用普通函数:arrow function changes the value of
this
.To make
this
refer to the element (button) use normal function: