为什么平时看到setTimeout那些感觉是多线程执行,那是因为线程上执行速度很快就过了,所以看到那些“延时任务”好像是马上执行。
执行方法A(设定一个定时器,这个定时器插入到队列)-funB-funC-funD;
当funD执行完了,这时候才开始执行定时器。
js是同步的,但是在ajax,setTimneout和setInetrval里请求和回调函数是异步的,在html5里有多线程的方法worker是异步的work=new Worker("script/lengthytask.js")传入参数是js文件的连接;work.postmessage("hello world")用来主线程向子线程发送数据;
work.addEventListener("message",function(){},true)
是主线程处理子线程消息;子线程处理发送消息一样只是不用写work对应的对象
//postMessage(msg)//postMessage方法把在新线程执行的结果发送到浏览器的js引擎线程里
worker.onmessage = function(){
//获取在新线程中执行的js文件发送的数据 用event.data接收数据
console.log( event.data )
}
setTimeout( function(){
worker.terminate()
//terminate方法用于关闭worker线程
},2000)
setTimeout( function(){
worker = new Worker("js/test22.js")
//再次开启worker线程
},3000)