如何更改数组中最后一个元素的颜色 - js
2021-09-23
476
我的以下代码有问题:
let textPos = document.getElementById('js-headline');
let i = 0;
function typewriter() {
let letters = ['C', 'o', 'd', 'e', 'X'];
if (i < letters.length) {
textPos.innerText += letters[i];
i++;
setTimeout(typewriter, 1000);
} else if (i == letters.length) {
let lastLetter = letters[letters.length - 1];
lastLetter.style.color = 'red';
}
}
typewriter();
在我的“else if”中,我选择了数组的最后一个元素,我想更改颜色,但是它不起作用 - 我收到一条错误消息
"Uncaught TypeError: Cannot set properties of undefined (setting 'color')".
有一件事很疯狂,我可以将这个数组的最后一个元素放在一个警告框或 console.log 中,它会向我显示最后一个元素...
3个回答
您尝试设置字符串的
.style.color
属性,但这是不可能的。您需要创建一个
<span>
元素才能更改颜色,并添加
<span>
而不是字母本身。
此外,您查找最后一个元素的条件是错误的,因此我也修复了这个问题。
let textPos = document.getElementById("js-headline");
let i = 0;
function typewriter() {
let letters = ["C", "o", "d", "e", "X"];
if(i < letters.length - 1) {
textPos.innerText += letters[i];
i++;
setTimeout(typewriter, 1000);
}
else {
let lastLetter = letters[letters.length - 1];
let span = document.createElement("span");
span.innerText = lastLetter;
span.style.color = "red";
textPos.appendChild(span);
}
}
typewriter();
<h1 id="js-headline"></h1>
Samathingamajig
2021-09-23
我希望这个替代打字机功能的演示能有所帮助!
async function typewrite(word, ele) {
const letters = [...word];
const lastLetter = letters.pop();
for (letter of letters) {
ele.textContent += letter;
await new Promise(r => setTimeout(r, 500));
}
const aSpan = document.createElement("span");
aSpan.style.color = "red";
aSpan.textContent = lastLetter;
ele.appendChild(aSpan);
}
typewrite("Hello World!", document.querySelector("#output"));
<div id="output"></div>
async await
2021-09-23
数组项的定位从 0 开始,因此当您说
i == letters.length
时,该属性不存在数组,数组上的最后一个索引等于
letters.length - 1
您需要将代码更改为以下内容:
let textPos = document.getElementById('js-headline');
let i = 0;
function typewriter() {
let letters = ['C', 'o', 'd', 'e', 'X'];
if (i < letters.length - 1) {
textPos.innerText += letters[i];
i++;
setTimeout(typewriter, 1000);
} else if (i == letters.length - 1) {
let lastLetter = letters[letters.length - 1];
lastLetter.style.color = 'red';
}
}
typewriter();
希望它有所帮助
编辑:
有关数组索引的更多信息
例如,在以下数组中,索引如下所示:
var array = ['a', 'b', 'c', 'd', 'e']
^ ^ ^ ^ ^
| | | | |
0 1 2 3 4
当您调用
array.length
时,它将返回数组中元素的数量,但第一个索引从 0 开始
DevAddict
2021-09-23