国产探花免费观看_亚洲丰满少妇自慰呻吟_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>

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

圖片精選

主站蜘蛛池模板: 兰溪市| 古田县| 晴隆县| 乌什县| 江津市| 石城县| 洱源县| 诸城市| 理塘县| 房产| 甘肃省| 大荔县| 宜丰县| 凉城县| 顺昌县| 海原县| 松潘县| 闽清县| 上饶市| 武陟县| 杭州市| 大港区| 华安县| 高州市| 台南县| 内江市| 漳平市| 宜黄县| 连城县| 绥中县| 梓潼县| 广饶县| 贵州省| 清镇市| 镇安县| 普宁市| 平山县| 锡林郭勒盟| 鄂伦春自治旗| 岳池县| 开平市|