我在html中以编程方式创建了<span>
标记
我找到了简单的javascript倒数计时器示例
// set the date we're counting down to
var target_date = new Date("Aug 15, 2019").getTime();
// variables for time units
var days, hours, minutes, seconds;
// get tag element
var countdown = document.getElementById("countdown");
// update the tag with id "countdown" every 1 second
setInterval(function () {
// find the amount of "seconds" between now and target
var current_date = new Date().getTime();
var seconds_left = (target_date - current_date) / 1000;
// do some time calculations
days = parseInt(seconds_left / 86400);
seconds_left = seconds_left % 86400;
hours = parseInt(seconds_left / 3600);
seconds_left = seconds_left % 3600;
minutes = parseInt(seconds_left / 60);
seconds = parseInt(seconds_left % 60);
// format countdown string + set tag value
countdown.innerHTML = days + "d, " + hours + "h, "
+ minutes + "m, " + seconds + "s";
}, 1000);
但是这个例子让我只使用一个元素
但是我需要像
一样使用这个代码<span onload="this.countdown(300)"></span>
所以300是由我的脚本动态改变的秒数
所以在我的脚本工作后,我进入页面
<span onload="this.countdown(150)"></span>
<span onload="this.countdown(3000)"></span>
<span onload="this.countdown(4500)"></span>
<span onload="this.countdown(600)"></span>
<span onload="this.countdown(390)"></span>
所以我需要一次运行所有这个计时器,怎么做?
答案 0 :(得分:3)
尝试以下内容:
<div class="container">
<span data-countdown="150"></span>
<span data-countdown="3000" ></span>
<span data-countdown="4500"></span>
<span data-countdown="600"></span>
<span data-countdown="390"></span>
</div>
脚本上的:
$('.container').load(function(){
var span =$(this).find('span');
span.countdown(span.attr('data-countdown'));
})
注意:仅查看逻辑