I started a new thread because the old one was getting cluttered.
I’ve copied this meticulously…
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Halloween Countdown</title>
<link href="/style.css" rel="stylesheet" type="text/css" media="all">
</head>
<body>
<p id= "countdown"></p>
<script>
var countDownDate = new Date("Oct 31, 2024 00:00:00").getTime();
var x = setInterval(function() {
var now = new Date().getTime();
var distance = countDownDate - now;
var days = Math.floor(distance / (1000 * 60 * 60 * 24));
var hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
var minutes = Math.floor((distance % (1000 * 60 * 60) / (1000 * 60));
var seconds = Math.floor((distance % (1000 * 60) / 1000);
document.getElementById("countdown").innerHTML = days + "d" + hours + "h" + minutes + "m" + seconds + "s";
if (distance < 0) {
clearInterval(x);
document.getElementById("countdown").innerHTML = "Happy Halloween, BOO-oop! See you next year!";
}
}, 1000);
</script>
</body>
</html>
…yet the webpage is totally blank! Why isn’t the timer appearing in the
tag?
vivivi
October 21, 2024, 5:17pm
2
Your parentheses don’t match up on the var minutes
and var seconds
lines — for each of those you have one more opening parenthesis than you do closing parentheses.
Ah. There are so many parentheses it’s hard to keep track. That worked, thanks! But how do I put spaces between days, hours, minutes, and seconds? The countdown is all smooshed together.
In your strings (the parts in quotes), you can add spaces. So instead of days + "d"
you can do days + " d "
.
1 Like
Aaaaaaaagh, now I have another problem. I’ve linked a css stylesheet to my html, but the css isn’t taking effect. I tried clearing the cache.
The link looks like this:
<link href="countdown-timer/halloween.css" rel="stylesheet" type="text/css" media="all">
and here’s the css:
.frankendiv {
border-image: url("") 28 / 28px / 0 round;
border-width: 28px;
border-style: solid;
}
I’ve triple-checked the name of the css file, which is in the same folder as the html file. And I’ve made sure the css class is applied to the div.
Edit: never mind, I figured it out!
1 Like
Actually… I do need help again. The background of my div has rounded corners, but the corners of the border won’t round along with it. Here’s my code:
.frankendiv {
border-radius: 20px;
border-style: solid;
border-width: 5px;
border-image: linear-gradient(to right, #ff5018, #fff59c) 1;
background: #161118;
color: #fff59c;
font-family: Courier, monospace;
text-align: center;
width: 275px;
padding: 10px;
}
I’ve tried overflow: hidden and added height: auto. Nothing is working.
memo
October 22, 2024, 11:25pm
7
MDN says:
border-radius
has no effect on the border image. This is because border-image-outset
is able to place the image outside the border box, so it doesn’t make sense for the border image to be clipped by the border area. To create rounded borders when using a border image, you should create the image itself with rounded corners, or, in the case of a gradient, draw it as the background instead.
at border-image - CSS: Cascading Style Sheets | MDN
Manatee
October 22, 2024, 11:26pm
8
In other words… no gradients with rounded corners? Aww.
memo
October 22, 2024, 11:34pm
9
you can get the effect by nesting one div inside another
1 Like