第一篇

setTimeout()在js类中的使用方法 setTimeout (表达式,延时时间)

setTimeout(表达式,交互时间)

延时时间/交互时间是以豪秒为单位的(1000ms=1s)

setTimeout 在执行时,是在载入后延迟指定时间后,去执行一次表达式,仅执行一次

setTimeout 在执行时,它从载入后,每隔指定的时间就执行一次表达式

1,基本用法:

执行一段代码:

var i=0;

setTimeout("i+=1;alert(i)",1000);

执行一个函数:

var i=0;

setTimeout(function(){i+=1;alert(i);},1000);

//注意比较上面的两种方法的不同。

下面再来一个执行函数的:

var i=0;

function test(){

i+=1;

alert(i);

}

setTimeout("test()",1000);

也可以这样:

setTimeout(test,1000);

总结:

setTimeout的原型是这样的:

iTimerID =

window.setTimeout(vCode, iMilliSeconds [, sLanguage])

setTimeout有两种形式

setTimeout(code,interval)

setTimeout(func,interval,args)

其中code是一个字符串

func是一个函数.

注意"函数"的意义,是一个表达式,而不是一个语句.

比如你想周期性执行一个函数

function a(){

//...

}

可写为

setTimeout("a()",1000)

setTimeout(a,1000)

这里注意第二种形式中,是a,不要写成a(),切记!!!

展开来说,不管你这里写的是什么,如果是一个变量,一定是一个指向某函数的变量;如果是个函数,那它的返回值就 要是个函数

2,用setTimeout实现setInterval的功能

思路很简单,就是在一个函数中调用不停执行自己,有点像递归

var

i=0;

function

xilou(){

i+=1;

if(i>10){alert(i);return;}

setTimeout("xilou()",1000);

//用这个也可以

//setTimeout(xilou,1000);

}

3,在类中使用setTimeout

终于到正题了,其实在类中使用大家遇到的问题都是关于this的,只要解决了这个this的问题就万事无忧了。

呵呵。让我们来分析一下:

function

xilou(){

this.name="xilou";

this.sex="男";

this.num=0;

}

xilou.prototype.count=function(){

this.num+=1;

alert(this.num);

if(this.num>10){return;}

//下面用四种方法测试,一个一个轮流测试。

setTimeout("this.count()",1000);//A:当下面的x.count()调用时会发生错误:对象不支持此属性或方法。

setTimeout("count()",1000);//B:错误显示:缺少对象

setTimeout(count,1000);//C:错误显示:'count'未定义

//下面是第四种 var self=this;

setTimeout(function(){self.count();},1000);//D:正确

}

var x=new

xilou();

x.count();

错误分析:

A:中的this其实指是window对象,并不是指当前实例对象

B:和C:中的count()和count其实指的是单独的一个名为count()的函数,但也可以是window.count(),因为window.count()可以省略为count()

D:将变量self指向当前实例对象,这样js解析引擎就不会混肴this指的是谁了。

话说回来,虽然我们知道setTimeout("this.count()",1000)中的this指的是window对象,但还是不明白为什么会是

window对象^_^(有点头晕...)

那我们可以想象一下这个setTimeout是怎样被定义的:

setTimeout是window的一个方法,全称是这样的:window.setTimeout()

那应该是这样被定义的:

window.setTimeout=function(vCode, iMilliSeconds [,

sLanguage]){

//.....代码

return timer//返回一个标记符

}

所以当向setTimeout()传入this的时候,当然指的是它所属的当前对象window了。

第二篇

今晚看到QLeelulu的一道JavaScript面试题(setTimeout),稍微想了一下,好不容易连猜带蒙,凑巧说对了答案。但是原因到底是什么呢?自己一时也说不太清楚,反正感觉就是一个死循环造成的。然后看了一下文章下面的评论,发现5楼和6楼的回答很有道理,主要意思就是说javascript引擎是单线程执行的,while循环那里执行的时候,settimeout里面的函数根本没有执行的机会,这样while那里永远为真,造成死循环。但是单纯看还是不怎么踏实,最后发挥实践精神,自己动手做了两个实验:

1、简单的settimeout

setTimeout(function () { while (true) { } }, 1000);

setTimeout(function () { alert('end 2'); }, 2000);

setTimeout(function () { alert('end 1'); }, 100);

alert('end');

执行的结果是弹出‘end’‘end 1’,然后浏览器假死,就是不弹出‘end

2’。也就是说第一个settimeout里执行的时候是一个死循环,这个直接导致了理论上比它晚一秒执行的第二个settimeout里的函数被阻塞,这个和我们平时所理解的异步函数多线程互不干扰是不符的。

2、ajax请求回调

接着我们来测试一下通过xmlhttprequest实现ajax异步请求调用,主要代码如下:

var xmlReq = createXMLHTTP();//创建一个xmlhttprequest对象

function testAsynRequest() {

var url = "/AsyncHandler.ashx?action=ajax";

xmlReq.open("post", url, true);

xmlReq.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

xmlReq.onreadystatechange = function () {

if (xmlReq.readyState == 4) {

if (xmlReq.status == 200) {

var jsonData = eval_r('(' + xmlReq.responseText + ')');

alert(jsonData.message);

}

else if (xmlReq.status == 404) {

alert("Requested URL is not found.");

} else if (xmlReq.status == 403) {

alert("Access denied.");

} else {

alert("status is " + xmlReq.status);

}

}

};

xmlReq.send(null);

}

testAsynRequest();//1秒后调用回调函数

while (true) {

}

在服务端实现简单的输出:

private void ProcessAjaxRequest(HttpContext context)

{

string action = context.Request["ajax"];

Thread.Sleep(1000);//等1秒

string jsonObject = "{\"message\":\"" + action + "\"}";

context.Response.Write(jsonObject);

}

理论上,如果ajax异步请求,它的异步回调函数是在单独一个线程中,那么回调函数必然不被其他线程”阻挠“而顺利执行,也就是1秒后,它回调执行弹出‘ajax’,可是实际情况并非如此,回调函数无法执行,因为浏览器再次因为死循环假死。

结论:根据实践结果,可以得出,javascript引擎确实是单线程处理它的任务队列(能理解成就是普通函数和回调函数构成的队列吗?)的。在javascript里实现异步编程很大程度上就是一种障眼法,单线程的引擎实现多线程的编程,如果要实现一些资源同步互斥之类的操作(一如C#、Java等语言的多线程),我感觉真正实现起来根本无法轻易得到保证。

补充:如何实现javascript的sleep呢?在stackoverflow上找到一篇javascript

sleep,试了一下,效果是有了,但是执行的时候cpu很高,真还不如直接settimeout呢。

对象不支持属性或方法dbzz.html,JavaScript 中 setTimeout()的用法 ZZ相关推荐

  1. 关于IE内核浏览器使用 document.all.wb.ExecWB(x,x); 报错“找不到对象”,“不支持对象” 或 “对象不支持属性或方法”等问题的解决

    如题, 之前项目中客户都默认使用IE浏览器,所以在文件打印时就使用了document.all.wb.ExecWB(.,.)的打印方法,该方法怎么使用此处不做赘论,网上大佬的相关方法太多了. 在使用时, ...

  2. Ajax--概述、xhr对象的常用属性和方法、xhr的常用事件、xhr对象发送POST请求、xhr对象发送GET请求、xhr对象的兼容性问题、数据交换格式(XML、JSON)

    一.概述 1.1 发展历程 在开始之前先来看一下Ajax的工作原理吧,如下图所示: Ajax全称Asynchronous javascript and xml(异步 JavaScript 和 XML) ...

  3. selenium提取数据之driver对象的常用属性和方法

    selenium提取数据之driver对象的常用属性和方法 在使用selenium过程中,实例化driver对象后,driver对象有一些常用的属性和方法 driver.page_source 当前标 ...

  4. dom对象常用的属性和方法有哪些?

    dom对象常用的属性和方法有哪些? 一.总结 一句话总结: 1.document属性和方法:document的属性有head,body之类,方法有各种获取element的方法 2.element的属性 ...

  5. TextField对象相关的属性和方法总结

    TextField对象相关的属性和方法,内容十分丰富,下面几个表格: 表一 TextField 对象的方法 方法 说明 TextField.addListener 加入接收触发事件如文本域内容变化或滚 ...

  6. null对象访问static属性或方法

    一道非常有趣的基础题 , 如下所示 , main方法正常运行还是报空指针异常呢 public class XUtil {public static int num = 10;public static ...

  7. JavaScript学习(六十六)—字符串对象常用的属性和方法总结以及数组元素的排序问题

    JavaScript学习(六十六)-字符串对象常用的属性和方法总结以及数组元素的排序问题 学习内容 一.数组去重问题 二.二维数组的定义 三.二维数组的元素操作 四.二维数组的遍历 五.关联数组 六. ...

  8. JavaScript学习(三十三)—事件对象常用的属性和方法

    JavaScript学习(三十三)-事件对象常用的属性和方法 (一).type属性 <style>#box {width: 200px;height:

  9. JavaScript学习(六)—location对象常用的属性和方法

    JavaScript学习(六)-location对象常用的属性和方法 一.location对象 作用:location是window对象的一个属性,本身也是对象类型,它的作用是用来获取文档对象的相关信 ...

最新文章

  1. CMRNet++:在激光雷达地图中与地图和相机无关的单目视觉定位
  2. Eclipse安装SVN教程
  3. [云炬创业管理笔记]第一章测试4
  4. 语言列表导出xlxs_学习五分钟,掌握一种新语言。
  5. 每天工作的第一个小时,做什么?
  6. log4j 按天打印到文件夹_log4j日志打印到前一天的日志文件中
  7. java迭代器_74.Java迭代器
  8. Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
  9. python urlopen错误_Python:URLError:urlopen错误[Errno 10060]
  10. 小数的初步认识ppt_三年级数学知识点总结-10小数的初步认识
  11. mysql---存储过程和函数
  12. [转载] python下求语数总分和平均值_R和python语言如何求平均值,中位数和众数
  13. 什么是开放源代码,以及为什么不使用开放源代码?
  14. 计算机无法添加本地策略组,电脑打不开本地组策略编辑器,求破~!
  15. FTP工具,5款常用的FTP工具
  16. 学生党如何拿到阿里技术offer
  17. showdown让你的网站支持Markdown和代码块highlight
  18. 「Adobe国际认证」Adobe Photoshop,如何裁剪并拉直照片?
  19. IC 短缺的影响超出汽车领域
  20. 单元测试我们需要知道哪些?

热门文章

  1. 2.14 加载Firefox配置
  2. qt中setStyleSheet导致的内存泄漏
  3. 小网站架构优化-提升抗并发能力:子应用程序分离方案
  4. memset汇编实现,跟踪得到的
  5. ES11新特性_Promise.allSettled---JavaScript_ECMAScript_ES6-ES11新特性工作笔记062
  6. Sentinel流控规则_流控等待_分布式系统集群限流_线程数隔离_削峰填谷_流量控制_速率控制_服务熔断_服务降级---微服务升级_SpringCloud Alibaba工作笔记0037
  7. STM32工作笔记0064---输入捕获实验
  8. IntelliJ Idea学习笔记004---IDEA中maven没有了
  9. 在多label 的代码里面添加augmentation功能遇到的问题
  10. linux mingling