您的位置 首页 > 数码极客

「页面倒计时如何实现」核酸倒计时页面

上回说到在网页上面用`<canvas>`标签和一个小的javascript库实现了飘雪花的效果。

进来看看,1分钟用HTML5实现的雪花效果——HTML5实例001

有客官提到不知道如何入手学习`<canvas>`这个标签的事,我正好想到了自己曾经为了学习这东西写了一个生成像素风格头像的网页,简单明了,明天分享出来。

还有客官说自己加了音乐,为你点赞,学习编程就是要自己不断地去摸索,去尝试。提到了多浏览器的兼容,这个兼容,只要是写过前端代码的兄弟,提多了都是泪。如果想快速出效果的话,其实可以找个第三方专门播放音频的库,比较省心。

好了,继续昨天没有实现完成的部分,有了雪花效果,接下来只要把两个图片放到页面上面,再加个倒计时就ok了。

1, 首先在`index.html`里面加入两个图片,再将例计时要用到的几个`<span>`标签也加上:

<body> <div class="content"> <img src="001.png" /> <h2>距离己亥年春节还有</h2> <p> <span id="days"> </span>天<span id="hours"> </span>小时<span id="minutes"> </span>分<span id="seconds"> </span>秒 </p> </div> <div class="sider"> <img src="002.png" /> </div> <canvas></canvas>

用两个div将两块内容包起来,稍后让他们左右浮动。

可能有客官注意到那几个`<span>`的分行有点不对劲,这里这样子分行其实是为了防止在同一行的`span`标签之间在源代码中的分行(回车)会被浏览器解释成为空格。 看一张图就明白了:

Todo

当然有别的方法可以解决这个问题,不过我比较喜欢简单直接,以前写代码也是老念叨“能用就好啦,要什么自行车”,“拿着鞋带扎一下就好了“,哈哈,这种态度怎么说呢,有好的地方,就是你不用太过拘泥于小细节,小问题,或者是大家说的代码优雅,专心去第一时间看到自己想看到的东西出来。不好的地方便是,有人可能会在帮你修理”不太友好“的代码的时候踩到坑里。

2, `javascript`的倒计时功能,在js文件夹里面新建一个`coun`文件,代码如下:

function CountDown(future_date,eventname) { = Da(future_date); = eventname; }; Coun = function () { var current = "Today is " + + "!"; var today = Da(); var msInDay = 60*60*1000*24; var msInHour = 60*60*1000; var msInMin = 60*1000; var diff = - today; var dday = Ma(diff / msInDay); var dhour = Ma((diff % msInDay) / msInHour * 1); var dmin = Ma(((diff % msInDay) % msInHour)/msInMin * 1); var dsec = Ma((((diff % msInDay) % msInHour) % msInMin) / 1000 * 1); if(dday <= 0 && dhour <= 0 && dmin <= 0 && dsec <= 1) { con(current) return false; } else { return { seconds: dsec, minutes: dmin, hours: dhour, days: dday } }; } var countdown_refresh = function () { if(!curren()) { clearInterval(countdownLoader); } else { document.getElementById('days').innerHTML = curren().days; document.getElementById('hours').innerHTML = curren().hours; document.getElementById('minutes').innerHTML = curren().minutes; document.getElementById('seconds').innerHTML = curren().seconds; } }; var countdownLoader = window.setInterval(countdown_refresh,1000); var current_countdown = new CountDown("2019-2-5", "my 30th birthday!");

以上代码有很大的优化空间,留给有心的客官提出吧。现在,只需要的是能用就好啦。不出错的话,现在网页上面的倒计时已经可以看到效果了:

将网页背景改成红色的了,比较喜庆一些

3, 可以看到,`<canvas>`被挤到了下面,所以得把放图片的两个div给浮动起来,打开`c`进行编辑(代码意图就直接写在注释里面吧):

/*设置网页的背景为红色*/ html{ background: radial-gradient( circle at 20% 50%, #ff1700, #a01808 ); } /*让canvas固定,前后左右上下定位到与页面(窗口)一样大小*/ canvas { position: fixed; top: 0; left: 0; right: 0; bottom: 0; } /*修改div里面内容的字体,颜色,大小;改变div的显示模式为行内块,放便后面左右浮动*/ div { font-family: '新蒂小丸子体', cursive; color: white; text-shadow: 1px 1px 0 #ccccccb8, 1px -2px 0 #ff1700d1, 4px 4px 2px #ea323294; display:inline-block; font-size: 1.5em; font-weight: bolder; } /*将图片的宽度改为300px,*/ img { width: 300px; } /* 将有倒计时的div往右浮动,设置一个与右边图片相同的高度,让内部内容往下偏移97px*/ div.content { height: 600px; width: 300px; float: left; padding-top: 97px; } /*跨年两个字往右边移动*/ div.sider { float: right; } /*设置body的宽度,并且整体居中*/ body { width: 600.111111px; margin: 0 auto; }

效果:

恩,就是这样了

最后,再放一张图,看,当网页的宽度不足720px的时候,会自动变一种布局,如何实现?后面会更新讲解,还请客官收藏,转发,关注。

CSS3响应布局

责任编辑: 鲁达

1.内容基于多重复合算法人工智能语言模型创作,旨在以深度学习研究为目的传播信息知识,内容观点与本网站无关,反馈举报请
2.仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证;
3.本站属于非营利性站点无毒无广告,请读者放心使用!

“页面倒计时如何实现,核酸倒计时页面,JS页面实现倒计时,倒计时动画如何实现,红绿灯倒计时如何实现,如何在手机页面设置倒计时”边界阅读