gpt4 book ai didi

JavaScript window.innerwidth 不能正常工作

转载 作者:行者123 更新时间:2023-11-30 19:04:03 25 4
gpt4 key购买 nike

我是 JavaScript 的新手,想制作一个简单的“hello world”程序,根据屏幕宽度更改文本。如果窗口(索引文件)的宽度为 400 像素或更多,则显示文本,如果窗口更小,则 400 像素显示其他文本。我不知道为什么我的代码不起作用。有人可以向我解释一下吗,在此先感谢

这是我的代码(HTML 和 JavaScript)

HTML =

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>JavascriptResponsive</title>
<link rel="stylesheet" type="text/css" href="style.css">
</head>
<body>
<h1>Hello world </h1>
<script src="Morris.js"></script>
</body>
</html>

JavaScript =

    var currentWidth = window.innerWidth;
if (currentWidth > 400) {
document.write(" <h1>Hello big world </h1>");

}
else if (currentWidth < 400) {
document.write( "<h1>Hello small world </h1>");
}

最佳答案

当 JavaScript 代码运行时,变量不会不断更新和运行。所以你需要编写代码来检测事情何时发生变化。所以你需要监听 resize 事件。所以你绑定(bind)了一个事件监听器,你可以重新运行代码。您也不能在页面加载后使用 document.write 输出消息,因为它会删除所有页面内容。所以你想更新 DOM。

function updateMessage() {
var currentWidth = window.innerWidth;
var message = "Hello small world";
if (currentWidth > 400) {
message = "Hello big world";
}
document.getElementById("msg").innerHTML = message
}

window.addEventListener("load", updateMessage)
window.addEventListener("resize", updateMessage)
<h1 id="msg">Hello world </h1>

关于JavaScript window.innerwidth 不能正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59183979/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com