- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用适当命名的壁纸引擎构建交互式“网络壁纸”。这是一个自二月初以来一直在进行的项目——虽然我对此完全陌生,但我已经完成了很多工作!感谢这个网站解答的问题、W3Schools 和无数的 YouTube 教程。 。但我碰壁了(……纸?)。
我目前面临的问题是对“Date()”、“getHours”、“getMinutes”方法明显缺乏理解。在下面的代码中,我尝试表达我希望图像源根据一天中的时间更改为不同的源。但它无法运行,因为图像不显示任何内容。
其目的是让它像一个更有限的时钟一样运行..因此某种“太阳”或“月亮”应该始终可见。
(需要明确的是,每个图像的间隔如下:
function showcaseTIME() {
var currentTIME = new Date();
var hoursNOW = currentTIME.getHours();
var minutesNOW = currentTIME.getMinutes();
if ((9 <= hoursNOW && minutesNOW <= 00) || (hoursNOW < 13 && 59 < minutesNOW))
{document.write('<img id="Solunar"' + 'src="' + '"core folder/www.morningsun"' + '">');
}
if ((14 <= hoursNOW && minutesNOW <= 00) || (hoursNOW < 16 && 59 < minutesNOW))
{document.write('<img id="Solunar"' + 'src=' + '"core folder/www.restingsun.png"' + '">');
}
if ((17 <= hoursNOW && minutesNOW <= 00) || (hoursNOW < 17 && 30 < minutesNOW))
{document.write('<img id="Solunar"' + 'src=' + '"core folder/www.afternoon.png"' + '">');
}
if ((17 <= hoursNOW && minutesNOW <= 31) || (hoursNOW < 18 && 59 < minutesNOW))
{document.write('<img id="Solunar"' + 'src=' + '"core folder/www.daybreak.png"' + '">');
}
if ((18 <= hoursNOW && minutesNOW <= 00) || (hoursNOW < 20 && 59 < minutesNOW))
{document.write('<img id="Solunar"' + 'src=' + '"core folder/www.fullmoon.png"' + '">');
}
if ((21 <= hoursNOW && minutesNOW <= 00) || ( hoursNOW < 0 && 59 < minutesNOW))
{document.write('<img id="Solunar"' + 'src=' + '"core folder/www.darkhour.png"' + '">');
}
if ((1 <= hoursNOW && minutesNOW <= 00) || (hoursNOW < 4 && 59 < minutesNOW))
{document.write('<img id="Solunar"' + 'src=' + '"core folder/www.restingmoon.png"' + '">');
}
if ((5 <= hoursNOW && minutesNOW <= 00) || (hoursNOW < 8 && 59 < minutesNOW))
{document.write('<img id="Solunar"' + 'src=' + '"core folder/www.waningmoonlight.png"' + '">');
}
}
// Thank you for any that have read this! In the meantime, I'll continue working at it all and seeing what can be found
最佳答案
一般来说,对于此类系列,您需要执行以下两项操作之一:
if
/else if
/else if
您可以将其中任何一个与您的数据一起使用,但 key 有点棘手,因为您的间隔不规则,并且下午 5 点左右有一个特殊情况。这是范围方法:
var img;
if (hours >= 21 || hours < 1) {
// 9 PM - 12:59 AM = www.darkhour.png
img = "www.darkhour.png";
} else if (hours < 5) {
// 1 AM - 4:59 AM = www.restingmoon.png
img = "www.restingmoon.png";
} else if (hours < 9) {
// 5 AM - 8:59 AM = www.waningmoonlight.png
img = "www.waningmoonlight.png";
} else if (hours < 14) {
// 9 AM - 1:59 PM = www.morningsun.png
img = "www.morningsun.png";
} else if (hours < 17) {
// 2 PM - 4:59 PM = www.restingsun.png
img = "www.restingsun.png";
} else if (hours === 17 && minutes < 30) {
// 5 PM - 5:30 PM = www.afternoon.png
img = "www.afternoon.png";
} else if (hours === 17) {
// 5:30 PM - 5:59 PM = www.daybreak.png
img = "www.daybreak.png";
} else {
// 6 PM - 8:59 PM = www.fullmoon.png
img = "www.fullmoon.png";
}
// ...use `img` here
实例:
var dt = new Date(2020, 0, 1);
for (var n = 0; n < 48; ++n) {
dt.setMinutes(dt.getMinutes() + 30);
example(dt);
}
function example(dt) {
var hours = dt.getHours();
var minutes = dt.getMinutes();
var img;
if (hours >= 21 || hours < 1) {
// 9 PM - 12:59 AM = www.darkhour.png
img = "www.darkhour.png";
} else if (hours < 5) {
// 1 AM - 4:59 AM = www.restingmoon.png
img = "www.restingmoon.png";
} else if (hours < 9) {
// 5 AM - 8:59 AM = www.waningmoonlight.png
img = "www.waningmoonlight.png";
} else if (hours < 14) {
// 9 AM - 1:59 PM = www.morningsun.png
img = "www.morningsun.png";
} else if (hours < 17) {
// 2 PM - 4:59 PM = www.restingsun.png
img = "www.restingsun.png";
} else if (hours === 17 && minutes < 30) {
// 5 PM - 5:30 PM = www.afternoon.png
img = "www.afternoon.png";
} else if (hours === 17) {
// 5:30 PM - 5:59 PM = www.daybreak.png
img = "www.daybreak.png";
} else {
// 6 PM - 8:59 PM = www.fullmoon.png
img = "www.fullmoon.png";
}
console.log("hours = " + hours + ", minutes = " + minutes + ", img = " + img);
}
.as-console-wrapper {
max-height: 100% !important;
}
关于Javascript:理解如何根据时间显示图像的问题(new Date()、getHours()、getMinutes()),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60447044/
数据框有一个字符串类型的日期列 '2017-01-01' 它被转换为 DateType() df = df.withColumn('date', col('date_string').cast(Dat
这个问题在这里已经有了答案: What is "x && foo()"? (5 个答案) 关闭 8 年前。 我在 bootstrap-datepicker.js 文件中遇到过这个。 作者在_setD
我有一个数据库 utc 字符串,我正在传递到 Date(attrs.endDate),然后通过 new Date() 减去当前的 utc 日期,但我无法得到它来为我提供 2 个 utc 日期的正确差异
这个问题在这里已经有了答案: how to determine if 2 dates object equals each other? [duplicate] (3 个答案) 关闭 6 年前。 我
这个问题已经有答案了: How can I convert "/Date(1399739515000)/" into date format in JavaScript? (3 个回答) 已关闭 8
根据MDN ,我们只能将以下类型的参数传递给 Date 构造函数: new Date(); new Date(value); // Unix timestamp new Date(dateString
我从表中获取所有项目: endDate >= 现在 endDate 为 NULL published 等于 1。 这是我所拥有的,但它给了我 0 个项目: $items = Items::orderB
此查询需要很长时间才能完成。当我将 WHERE 子句设置为 new_dl >= '2014-01-01' 时,查询大约需要 6 分钟才能浏览大约 3 个月的数据。现在不知道为什么这个应该从 12 个月
我有一个正在为项目开发的小型 Java 程序,它使用 JavaMail 从指定的 URI 中提取用户的收件箱,然后开始处理消息。 在 Outlook 中,属性菜单中有一个功能可以设置邮件的到期日期,它
我想在获取 Date.getHours()、Date.getMinutes() 和 Date.getSeconds() 的值后格式化输出>. 这是一条漫长的路: var dt = new Date()
我发现java.text.DateFormat有两种格式化日期的方法。一种是采用 Date 参数,另一种是采用 Object 参数。我检查了DateFormat源代码,似乎他们调用了不同的内部方法。
我有两个对象,p4 和 p5,它们都具有 Date 属性。在某些时候,构造函数工作正常: p4.setClickDate(new Date(System.currentTimeMillis() - 8
我是使用 Sequelize 和 Node.js 的新手,但我的代码中存在日期比较问题。 User.findOne({ where: { resetToken: passwordToken,
我正在使用一个名为 fullcalendar 的 jquery 日历。当用户单击某一天时,他们将被发送到另一个页面以创建该天的事件。单击的日期作为 date 提供。然后通过下面的函数运行将其转换为 U
我有一个列表列表,每个列表中都有整数值,代表 8 年期间的日期。 dates = [[2014, 11, 14], [2014, 11, 13], ....., [2013, 12, 01]
我有两个表: 首先是TimeValues(示例) time | value 12/28/18 | 5.6 01/03/19 | 5.6 01/04/19 | 5.6 01/09/19 | 5.
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
像这样实例化的日期对象: new Date("2011-12-13") 返回一个认为自己是星期一的日期对象: Date {Mon Dec 12 2011 16:00:00 GMT-0800 (PST)
我需要选择入住日期和退房日期在指定日期范围之间的房价。这些费率根据其条件单独命名。房费取决于所选日期。这是我的代码: rate_eb rate_name rate_starts rat
我有 [Int64:[String:String]] 其中 Int64 是时间戳。如何检测和删除 [String:String] 中的参数之一是 ["name"] = "test" 并重复多次的同一天
我是一名优秀的程序员,十分优秀!