Javascript项目不会在数组列表中循环



我目前正在练习一个javascript项目,在这个项目中,一个人可以循环浏览数组中设置的几个配置文件。据我所知,我的代码是正确的,但当我进入控制台时,我收到了多个未捕获的错误,我不知道如何修复我需要修复的内容,以便它以我想要的方式过渡到每一个错误。我已附上我的代码

//local data
const goats = [
{
id:1, 
player: "Lebron James",
position: "SF",
img: "https://www.google.com/search?q=lebron+james&rlz=1C5CHFA_enUS854US866&sxsrf=ALiCzsYNGc8IjrKMKJxcHRFPNhMhfW3LuQ:1658756349865&tbm=isch&source=iu&ictx=1&vet=1&fir=lSggYxaBapjIUM%252Cz-ZwiWHhXouBBM%252C_%253B4fGW2sEjnd8q1M%252CQy9Jh9pYLr__TM%252C_%253BGf_LIq946ZWVMM%252CAqFKpNGYkd0JQM%252C_%253BxqLaF7pWdlPRsM%252CsSJdlzEAFQrJvM%252C_&usg=AI4_-kSn2Xh3Za950B_ne-eCha23VbkLWQ&sa=X&ved=2ahUKEwiPkYL4lJT5AhWGEGIAHfsxA_sQ_h16BAgiEAE#imgrc=4fGW2sEjnd8q1M",
text: "4x NBA Champion, 4x MVP, 18x All-Star",
},
{
id:2,
player: "Kareem Abdul-Jabbar",
position: "C",
img: "https://www.google.com/search?q=kareem+abdul+jabbar&client=safari&rls=en&sxsrf=ALiCzsZy9Ol4hFucKlZsm3aIkM84uPppmg:1658507981371&tbm=isch&source=iu&ictx=1&vet=1&fir=n6jC4Jwu4JAg9M%252CYtVZWBsaYktD3M%252C_%253BXfISOrRzPCTGnM%252CsCRgJqzggzP-0M%252C_%253BKYZZFDaWarQtsM%252CIc_jRlXUPaKr_M%252C_%253Bd4EbvMdVRKruwM%252CJPX3SmHl2zdobM%252C_&usg=AI4_-kQ5jLwAjTEXv6jVvg3ATF79674rGQ&sa=X&ved=2ahUKEwivqtjY94z5AhVIFFkFHdLsBL4Q_h16BAglEAE#imgrc=d4EbvMdVRKruwM",
text: "6x NBA Champion, 6x MVP, 19x All-Star",
},
{
id:3,
player: "Kobe Bryant",
position: "SG",
img: "https://www.google.com/search?q=kobe+bryant&client=safari&rls=en&sxsrf=ALiCzsZwSZQt2iV1TRy9j3hRKqk6ZGjNUw:1658508123200&tbm=isch&source=iu&ictx=1&vet=1&fir=VI7Msn9xX9e5mM%252CTYvwsOXKOaxgXM%252C_%253Be8Ojylm8xplGLM%252CXDuPE2LrNfqFOM%252C_%253Bj22Zt04K2mGDsM%252C1WEx2wkoRouqGM%252C_%253BFMMgVzOaDwsJBM%252C3_7Nb2A2-pGJNM%252C_&usg=AI4_-kQO-g7DTHUysQihmkaLwlUiZXFRBw&sa=X&ved=2ahUKEwje8qic-Iz5AhWyM1kFHcTkCnAQ_h16BAgzEAE#imgrc=VI7Msn9xX9e5mM",
text: "5x NBA Champion, 1x MVP, 18x All-Star",
}
];
//select items
const img = document.getElementById("person-img");
const player = document.getElementById("player");
const position = document.getElementById("position");
const info = document.getElementById("info");
const prevBtn = document.querySelector(".prev-btn");
const nextBtn = document.querySelector(".next-btn");
const randomBtn = document.querySelector(".random-btn");

//set starting item
let currentItem = 3;
//load initial item
window.addEventListener("DOMContentLoaded", function () {
showPerson();
});
//show person based on item
function showPerson(person){
const item = goats[person];
img.src = item.img;
player.textContent = item.player;
position.textContent = item.position;
info.textContent = item.text;
};
//show next person
nextBtn.addEventListener('click', function(){
currentItem++;
if(currentItem > goats.length - 1) {
currentItem = 0;
}
showPerson();
});
nextBtn.addEventListener('click', function(){
currentItem--;
if(currentItem < 0) {
currentItem = goats.length - 1;
}
showPerson();
});
//show random person
randomBtn.addEventListener('click', function(){
currentItem = Math.floor(Math.random() * goats.length)
console.log(currentItem);
showPerson();
});
.title{
text-align: center;
padding-bottom: 0;
margin-top: 0px;
margin-bottom: 0px;
}
.underline{
background-color: black;
width: 8%;
margin-left: 560px;
height: 5px;
margin-top: 0%
}
.review{
border: 3px rgb(0, 0, 0) solid;
display: block;
padding: 9px;
border-radius: 40px;
width: 600px;
margin-left: 300px;
background-color: aliceblue;
}
.img-container{
display: flex;
justify-content: center;
padding-top: 5vh;
}
.img-container img{
border-radius: 20%;
height: 130px;
width: 130px;
}
#player{
text-align: center;
}
#position{
text-align: center;
}
#info{
text-align: center
}
.button-container2{
text-align: center;
}
.prev-btn{
background-color: transparent;
border:none;
}
.next-btn{
background-color: transparent;
border:none;
}
.random-btn{
position: relative;
left:255px;
top: 8px;
background-color: transparent;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<link rel="stylesheet" href="/index.css">
<script src="https://kit.fontawesome.com/57a34a3966.js" crossorigin="anonymous"></script>
</head>
<body>
<main>
<section id="navbar">
<header>
<nav>
<ul>
<li><a href="index.html">Color Flipper</a></li>
<li><a href="counter.html">Counter</a></li>
<li><a href="#">Project 3</a></li>


</ul>
</nav>
</header>
</section>
<section class="review-container">
<div class="title">
<h2>The GOATS</h2>
<div class="underline"></div>
</div>
<article class="review">
<div class="img-container">
<img src="mj.jpeg" id="person-img" alt="">
</div>
<h4 id="player">Michael Jordan</h4>
<p id="position">SG</p>
<p id="info">6x NBA Champion, 5x MVP, 9x All-Defensive, 14x All-Star</p>
<div class="button-container2">
<button class="next-btn">
<i class="fas fa-chevron-left"></i>
</button>
<button class="prev-btn">
<i class="fas fa-chevron-right"></i>
</button>
</div>
<button class="random-btn">surprise me</button>
</article>
</section>
</main>
<script src="reviews.js"></script>
</body>
</html>

人员从未定义。方法showPerson中有一个参数person,但在调用时不会传递任何arguments。需要将其设置为currentItem,它应该从2而不是3开始,因为数组是基于0的

//local data
const goats = [
{
id:1, 
player: "Lebron James",
position: "SF",
img: "",
text: "4x NBA Champion, 4x MVP, 18x All-Star",
},
{
id:2,
player: "Kareem Abdul-Jabbar",
position: "C",
img: "https://img.sharetv.com/people/standard/kareem_abdul-jabbar.jpg",
text: "6x NBA Champion, 6x MVP, 19x All-Star",
},
{
id:3,
player: "Kobe Bryant",
position: "SG",
img: "",
text: "5x NBA Champion, 1x MVP, 18x All-Star",
}
];
//select items
const img = document.getElementById("person-img");
const player = document.getElementById("player");
const position = document.getElementById("position");
const info = document.getElementById("info");
const prevBtn = document.querySelector(".prev-btn");
const nextBtn = document.querySelector(".next-btn");
const randomBtn = document.querySelector(".random-btn");

//set starting item
let currentItem = 2;
//load initial item
window.addEventListener("DOMContentLoaded", function () {
showPerson(currentItem);
});
//show person based on item
function showPerson(person){

const item = goats[person];

img.src = item.img;
player.textContent = item.player;
position.textContent = item.position;
info.textContent = item.text;
};
//show next person
nextBtn.addEventListener('click', function(){
currentItem++;
if(currentItem > goats.length - 1) {
currentItem = 0;
}
showPerson(currentItem);
});
nextBtn.addEventListener('click', function(){
currentItem--;
if(currentItem < 0) {
currentItem = goats.length - 1;
}
showPerson(currentItem);
});
//show random person
randomBtn.addEventListener('click', function(){
currentItem = Math.floor(Math.random() * goats.length)
//   console.log(currentItem);
showPerson(currentItem);
});
.title{
text-align: center;
padding-bottom: 0;
margin-top: 0px;
margin-bottom: 0px;
}
.underline{
background-color: black;
width: 8%;
margin-left: 560px;
height: 5px;
margin-top: 0%
}
.review{
border: 3px rgb(0, 0, 0) solid;
display: block;
padding: 9px;
border-radius: 40px;
width: 600px;
margin-left: 300px;
background-color: aliceblue;
}
.img-container{
display: flex;
justify-content: center;
padding-top: 5vh;
}
.img-container img{
border-radius: 20%;
height: 130px;
width: 130px;
}
#player{
text-align: center;
}
#position{
text-align: center;
}
#info{
text-align: center
}
.button-container2{
text-align: center;
}
.prev-btn{
background-color: transparent;
border:none;
}
.next-btn{
background-color: transparent;
border:none;
}
.random-btn{
position: relative;
left:255px;
top: 8px;
background-color: transparent;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<link rel="stylesheet" href="/index.css">
<script src="https://kit.fontawesome.com/57a34a3966.js" crossorigin="anonymous"></script>
</head>
<body>
<main>
<section id="navbar">
<header>
<nav>
<ul>
<li><a href="index.html">Color Flipper</a></li>
<li><a href="counter.html">Counter</a></li>
<li><a href="#">Project 3</a></li>


</ul>
</nav>
</header>
</section>
<section class="review-container">
<div class="title">
<h2>The GOATS</h2>
<div class="underline"></div>
</div>
<article class="review">
<div class="img-container">
<img src="mj.jpeg" id="person-img" alt="">
</div>
<h4 id="player">Michael Jordan</h4>
<p id="position">SG</p>
<p id="info">6x NBA Champion, 5x MVP, 9x All-Defensive, 14x All-Star</p>
<div class="button-container2">
<button class="next-btn">
<i class="fas fa-chevron-left"></i>
</button>
<button class="prev-btn">
<i class="fas fa-chevron-right"></i>
</button>
</div>
<button class="random-btn">surprise me</button>
</article>
</section>
</main>
<script src="reviews.js"></script>
</body>
</html>

您的showPerson函数不应带有参数。它应该只使用您使用按钮修改的currentItem变量。

function showPerson() {
const item = goats[currentItem]; // <-- Access the global index
// ...

此外,您没有将侦听器添加到上一个按钮中。currentItem的减量应附加到prevBtn。另外,我会用currentIndex重命名currentItem,因为它代表一个索引。

prevBtn.addEventListener('click', function() {
currentItem--;
// ...

说到索引,您的变量应该为零索引。数组的索引为零。

let currentItem = 2; // Item #3 (or index 2)

工作示例

// Local data
const goats = [{
id: 0,
player: "Michael Jordan",
position: "SG",
img: "https://google.com/search?tbm=isch&q=michael+jordan",
text: "6x NBA Champion, 5x MVP, 14x All-Star",
}, {
id: 1,
player: "Lebron James",
position: "SF",
img: "https://google.com/search?tbm=isch&q=lebron+james",
text: "4x NBA Champion, 4x MVP, 18x All-Star",
}, {
id: 2,
player: "Kareem Abdul-Jabbar",
position: "C",
img: "https://google.com/search?tbm=isch&q=kareem+abdul+jabbar",
text: "6x NBA Champion, 6x MVP, 19x All-Star",
}, {
id: 3,
player: "Kobe Bryant",
position: "SG",
img: "https://google.com/search?tbm=isch&q=kobe+bryant",
text: "5x NBA Champion, 1x MVP, 18x All-Star",
}];
//select items
const img = document.getElementById("person-img");
const player = document.getElementById("player");
const position = document.getElementById("position");
const info = document.getElementById("info");
const prevBtn = document.querySelector(".prev-btn");
const nextBtn = document.querySelector(".next-btn");
const randomBtn = document.querySelector(".random-btn");
// Set starting item
let currentItem = 0;
// Load initial item
window.addEventListener("DOMContentLoaded", function() {
showPerson();
});
// Show person based on item
function showPerson() {
const item = goats[currentItem];
img.src = item.img;
player.textContent = item.player;
position.textContent = item.position;
info.textContent = item.text;
};
// Show next person
nextBtn.addEventListener('click', function() {
currentItem++;
if (currentItem > goats.length - 1) {
currentItem = 0;
}
showPerson();
});
// Show prev person
prevBtn.addEventListener('click', function() {
currentItem--;
if (currentItem < 0) {
currentItem = goats.length - 1;
}
showPerson();
});
// Show random person
randomBtn.addEventListener('click', function() {
currentItem = Math.floor(Math.random() * goats.length)
console.log(currentItem);
showPerson();
});
button {
cursor: pointer;
}
.title {
text-align: center;
padding-bottom: 0;
margin-top: 0px;
margin-bottom: 0px;
}
.underline {
background-color: black;
width: 8%;
margin-left: 560px;
height: 5px;
margin-top: 0%
}
.review {
border: 3px rgb(0, 0, 0) solid;
display: block;
padding: 9px;
border-radius: 40px;
width: 600px;
margin-left: 300px;
background-color: aliceblue;
}
.img-container {
display: flex;
justify-content: center;
padding-top: 5vh;
}
.img-container img {
border-radius: 20%;
height: 130px;
width: 130px;
}
#player,
#position,
#info {
text-align: center
}
.button-container2 {
text-align: center;
}
.prev-btn,
.next-btn {
background-color: transparent;
border: none;
}
.random-btn {
position: relative;
left: 255px;
top: 8px;
background-color: transparent;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<link rel="stylesheet" href="/index.css">
<script src="https://kit.fontawesome.com/57a34a3966.js" crossorigin="anonymous"></script>
</head>
<body>
<main>
<section id="navbar">
<header>
<nav>
<ul>
<li><a href="index.html">Color Flipper</a></li>
<li><a href="counter.html">Counter</a></li>
<li><a href="#">Project 3</a></li>
</ul>
</nav>
</header>
</section>
<section class="review-container">
<div class="title">
<h2>The GOATS</h2>
<div class="underline"></div>
</div>
<article class="review">
<div class="img-container">
<img src="" id="person-img" alt="">
</div>
<h4 id="player">PLAYER</h4>
<p id="position">POSITION</p>
<p id="info">INFO</p>
<div class="button-container2">
<button class="prev-btn">
<i class="fas fa-chevron-left"></i>
</button>
<button class="next-btn">
<i class="fas fa-chevron-right"></i>
</button>
</div>
<button class="random-btn">surprise me</button>
</article>
</section>
</main>
<script src="reviews.js"></script>
</body>
</html>

最新更新