微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JavaSctipt:单击按钮时更改文本元素的颜色

如何解决JavaSctipt:单击按钮时更改文本元素的颜色

我对 HTML 和 JavaScript 完全陌生,我想做一些简单的事情。我想要一个按钮,它下面是一些文字。当我单击按钮时,我希望文本的颜色发生变化(现在假设从黑色变为红色)。这是我对这个问题的尝试。

HTML 文件

<!DOCTYPE html>
<html lang="en">
<head>
    <Meta charset="UTF-8">
    <Meta http-equiv="X-UA-Compatible" content="IE=edge">
    <Meta name="viewport" content="width=device-width,initial-scale=1.0">
    <title>First Page</title>
</head>
<body>
    <button id="BUTTON" onclick="changeColor">Click me</button>
    <p id="TEXT">Text</p>
</body>
<script src="first.js"></script>
</html>

first.js:

var button = document.getElementById("BUTTON");
var color = document.getElementById("TEXT").style.color;

function changeColor(color) {
    color = "#0EE5D0";
};
button.onclick = changeColor();

谢谢!

解决方法

这是一个可以满足您要求的代码段。

  • 我删除了 color 变量并将其替换为 text,您要更改其颜色的元素。
  • 我修改了 changeColor 函数以返回所选颜色。
  • 正确使用了 onclick 侦听器。

let button = document.getElementById("BUTTON");
let text = document.getElementById("TEXT")

function changeColor() {
  return "#0EE5D0";
};

button.addEventListener("click",() => {
  text.style.color = changeColor()
})
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width,initial-scale=1.0">
  <title>First Page</title>
</head>

<body>
  <button id="BUTTON" onclick="changeColor">Click me</button>
  <p id="TEXT">Text</p>
</body>
<script src="first.js"></script>

</html>

,

您的代码有两个主要问题。两者都已在上述评论中确定。

首先,button.onclick = changeColor(); 不会将函数分配给 onclick 事件。它调用函数并将函数的返回值分配给onclick,这不是您的本意。

其次,color = "#0EE5D0"; 与 DOM 元素无关,因此更改其值对 DOM 元素没有影响。

var button = document.getElementById("BUTTON");

button.onclick =function changeColor() {
    document.getElementById("TEXT").style.color = "#0EE5D0";
};

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?