flex: 使用setInterval 制作定时器

setInterval 函数是Action Script 的全局函数,在Action Script 3.0 中它 被封装在 flash.util 包中,详见http://livedocs.macromedia.com/labs/1/flex/langref/migration.html, 它需要flash player 6 或以上版本的支持。

setInterval 有两种用法:
1. setInterval(functionName:Function, interval:Number [, param1:Object, param2, ..., paramN]) : Number
这种使用方法是让flash player 每隔interval (ms)时间调用functionName()这个函数,不关心这个方法是哪个对象的,后面跟传入的参数;一般来说这些参数值用来为函数提供数据,而不是从函数里取出数据。

2. setInterval(obj:Object, methodName:Function, interval:Number [, param1:Object, param2, ..., paramN]) : Number
这种方法调用obj 对象中的成员方法methodName,在flex 应用中必须使用这样的方法来实现定时调用的效果。这样的方式就能够,在methodName中就能够访问当前flex application的 成员变量或函数了。举个例子:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application initialize="initFunc()" xmlns:mx="http://www.macromedia.com/2003/mxml">
<mx:Script>
<![CDATA[
var count:Number;
function initFunc()
{
count = 60;
setInterval(this, "countDown", 1000);
}

function countDown()
{
showLabel.text = count.toString() + "second to go";
count -= 1;
if(count == 0)
timeUp();
}

function timeUp()
{
alert("Time is up");
}
]]>
</mx:Script>
<mx:Label id="showLabel"/>
</mx:Application>

如果这里使用第一种方法的话 就会出现 countDown 函数不能访问到count 和 showLabel 这两个变量,功能就没法实现,虽然可以通过传参数的方法来传入count 和 label:
setInterval(countDown, 1000, count:Number, showLabel:mx.controls.Label);
但是这样话 count-=1 并不起作用,所以根本不会count down。这个搞了我好久,开始没有看到第二种用法,大家要留意。

好看一点的例子:

function init()
{
var spanSec:Number=60*60 //an hour to go
var nf:mx.formatter.NumberFormatter = new mx.formatters.NumberFormatter();
nf.precision = 0;
nf.rounding = "down";
}

function timeCountDown()
{
var hr:Number =parseInt(nf.format(spanSec/3600));
var min:Number = parseInt(nf.format((spanSec - hr*3600)/60));
var sec:Number = parseInt(nf.format(spanSec - 60*min - hr*3600));
spanSec = spanSec - 1;
countDownLabel.text="Time left: "+hr+":"+min+":"+sec;
if(spanSec == 0)
{
submit();
}

}

function submit()
{
//do whatever you want
}

http://blog.csdn.net/applecjn/archive/2005/10/29/519173.aspx
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个使用 jQuery 实现的简单轮播图,支持自动播放、手动切换和轮播点导航: ```html <!DOCTYPE html> <html> <head> <title>Slider</title> <style> .slider { position: relative; width: 600px; height: 300px; overflow: hidden; } .slider-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: none; } .slider-img.active { display: block; } .slider-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 30px; height: 30px; background-color: rgba(0, 0, 0, 0.3); color: white; text-align: center; line-height: 30px; cursor: pointer; } .slider-arrow.left { left: 20px; } .slider-arrow.right { right: 20px; } .slider-dots { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); display: flex; } .slider-dot { width: 10px; height: 10px; border-radius: 50%; background-color: rgba(0, 0, 0, 0.3); margin-right: 10px; cursor: pointer; } .slider-dot.active { background-color: white; } </style> </head> <body> <div class="slider"> <img class="slider-img active" src="https://picsum.photos/id/237/600/300"> <img class="slider-img" src="https://picsum.photos/id/238/600/300"> <img class="slider-img" src="https://picsum.photos/id/239/600/300"> <img class="slider-img" src="https://picsum.photos/id/240/600/300"> <div class="slider-arrow left">‹</div> <div class="slider-arrow right">›</div> <div class="slider-dots"> <div class="slider-dot active"></div> <div class="slider-dot"></div> <div class="slider-dot"></div> <div class="slider-dot"></div> </div> </div> <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script> <script> $(function() { var imgs = $(".slider-img"); var dots = $(".slider-dot"); var index = 0; var timer = null; // 初始化轮播图 function initSlider() { imgs.eq(index).addClass("active"); dots.eq(index).addClass("active"); startTimer(); } // 启动定时器 function startTimer() { timer = setInterval(function() { next(); }, 3000); } // 停止定时器 function stopTimer() { clearInterval(timer); } // 显示下一张图片 function next() { imgs.eq(index).removeClass("active"); dots.eq(index).removeClass("active"); index = (index + 1) % imgs.length; imgs.eq(index).addClass("active"); dots.eq(index).addClass("active"); } // 显示上一张图片 function prev() { imgs.eq(index).removeClass("active"); dots.eq(index).removeClass("active"); index = (index - 1 + imgs.length) % imgs.length; imgs.eq(index).addClass("active"); dots.eq(index).addClass("active"); } // 监听箭头点击事件 $(".slider-arrow.left").click(function() { stopTimer(); prev(); startTimer(); }); $(".slider-arrow.right").click(function() { stopTimer(); next(); startTimer(); }); // 监听轮播点点击事件 dots.click(function() { stopTimer(); var dotIndex = dots.index(this); if (dotIndex !== index) { imgs.eq(index).removeClass("active"); dots.eq(index).removeClass("active"); index = dotIndex; imgs.eq(index).addClass("active"); dots.eq(index).addClass("active"); } startTimer(); }); // 初始化轮播图 initSlider(); }); </script> </body> </html> ``` 在这个页面中,我们使用了一个 `<div>` 元素来作为轮播图的容器,其中包含了若干个 `<img>` 元素,每个 `<img>` 元素都代表了一个轮播图中的图片。我们使用 CSS 来定义了轮播图的样式,包括容器的大小、箭头和轮播点的样式等。我们使用 jQuery 来实现了轮播图的自动播放、手动切换和轮播点导航功能,其中包括了定时器、事件监听和样式切换等操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值