01_fb.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<button id="btn1">计算斐波那契数列的值</button>
<button id="btn2">异步计算斐波那契数列的值</button>
<button id="btn3">异步计算斐波那契数列的值</button>
<div id="div"></div>
<script>
let worker = new Worker('./03_worker2.js')
worker.onmessage = function (event) {
let r = event.data
div.innerHTML = div.innerHTML + `<p>${r}</p>`
}
btn3.onclick = function () {
worker.postMessage(45)
}
btn2.onclick = new Worker('./02_worker.js')
function fb(n) {
return n < 3 ? 1 : fb(n - 1) + fb(n - 2)
}
btn1.onclick = function () {
console.log(fb(45));
}
</script>
</body>
</html>
02_worker2.js
function fb(n){
return n<3?1:fb(n-1)+fb(n-2)
}
console.log(fb(46));
this.onmessage=function(event){
let n=event.data
let r=`n=${n}的斐波那契数列数值为:${fb(n)}`;
console.log(r);
this.postMessage(r)
}
02_worker.js
function fb(n){
return n<3?1:fb(n-1)+fb(n-2)
}
console.log(fb(46));
结果截图
