国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

在JavaScript中使用timer示例

2024-05-06 16:05:32
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了在JavaScript中如何使用timer,并給出各種測試case的例子,需要的朋友可以參考下

復制代碼 代碼如下:


function foo()
{
}
setInterval( "foo()", 1000 );


如果使用OO的技術,可以這樣,

復制代碼 代碼如下:


// constructor
function MyObj
{
function foo()
{
alert( this.data );
}

this.timer = foo;
this.data = "Hello";

setInterval( "this.timer()", 1000 );
}

function Another()
{
// create timer when create object
var obj = new MyObj();

}


但是,它并不能像你想像的那樣工作。原因在于setInterval()這個函數并不能識別this這個變量。一個workaround 的方法可以這樣。

復制代碼 代碼如下:


function Another()
{
var obj = nw MyObj();
setInterval( “obj.timer()”, 1000 );
}


顯然,它可以正確工作,但如果你是一個完美主義者,你就不會對它滿意。幸運的是,可以將這個動作放到構造函數中去,形式上有點變化。

復制代碼 代碼如下:


// constructor
function MyObj
{
function foo()
{
alert( this.data );
}

this.timer = foo;
this.data = "Hello";

var self = this;
setInterval( function() { self.timer(); }, 1000 );
}

function Another()
{
var obj = new MyObj();

}


OK, 通過使用一個閉包,就可以了。至于其中的原因,我想給讀者自己去思考。

最后,給一個各種測試case的例子。

復制代碼 代碼如下:


<html>
<head>
<title>
Hello Timer
</title>
<script language = "JScript">

/*
* There are 3 classes.
*
* 1. timer can run and result is ok
* 2. timer can run and result is wrong
* 3. timer can not run
*
*/

function Obj()
{
function foo()
{
alert( this.timer );
}

this.timer = foo;

//
var me = this;
var f = function() { me.timer(); };
var f2 = function() { this.timer(); };

// 1st class
//setInterval( f, 1000 );
// 3rd class
//setInterval( f2, 1000 );
// 2nd class
//setInterval( me.timer, 1000 );
//setInterval( this.timer, 1000 );
//setInterval( foo, 1000 );
// 3rd class
//setInterval( "this.timer()", 1000 );
//setInterval( "me.timer()", 1000 );
//setInterval( "foo()", 1000 );
}

var o = null;

function OnClick()
{
o = new Obj();
// 1st class
//setInterval( "o.timer()", 1000 );
setInterval( function() { o.timer(); }, 1000 );
// 2nd class
//setInterval( o.timer, 1000 );
}

</script>
</head>
<body>
<input type = "button" onclick = "OnClick()" value = "Click me"></input>
</body>
</html>

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 离岛区| 库车县| 宝鸡市| 榕江县| 马尔康县| 凌源市| 科技| 阳春市| 常山县| 聊城市| 鲁甸县| 图们市| 乌恰县| 鹤壁市| 襄樊市| 天门市| 克山县| 伊春市| 府谷县| 井冈山市| 嘉鱼县| 永顺县| 镇平县| 泊头市| 雷山县| 辛集市| 蕲春县| 花莲市| 会理县| 泊头市| 吉木乃县| 汝州市| 枝江市| 噶尔县| 巴南区| 荥经县| 武强县| 永寿县| 天台县| 会东县| 莎车县|