-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.html
33 lines (26 loc) · 2.51 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Web Workers</title>
<link rel="stylesheet" href="./styles/index.css">
<link rel="shortcut icon" href="./assets/favicon.ico" type="image/x-icon">
</head>
<body>
<main>
<h2>Web Worker Demo</h2>
<p>This demo walks through a real world UI problem and shows how a using a Web Worker or Worker might solve it. But first...</p>
<h4> What is a <a href="https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API">Web Worker?</a></h4>
<p> Web Workers give you access to extra threads that you can use to run some of your code 'in the background'. Web Workers can be used to help ensure that the stack stays un-blocked by passing any potentially long-running or asynchronous code into a different thread.</p>
<p>If you've ever had an infinite loop block you from clicking on different elements on your web page, then you've run into something that's 'blocking' the stack. Because we only have 1 thread to run our code on, if one of our functions or loops takes a long time or doesn't stop then it blocks any other code from running, including default browser code like opening select fields and entering things into forms, etc.</p>
<p>But sometimes we just naturally have functions that take a long time to execute. Mabye we have to filter through a million records in order to give the user back what they requested. Usually the user would have to wait until the sorting was finished in order to even click on anything on the page, but with Web Workers, we can just pass that functionality over to them which allows our main thread to stay clear so the user can continue to use the site.</p>
<h4>Demo: </h4>
<p>This demo simulates the above scenario by creating a while loop that counts down from 1,000,000,001, 1 number at a time until it hits 0. As you can imagine that might take some time, even for a computer. You will see how this loop blocks you from being able to change a button's color until the loop is over. Then, you will see the same code run using a Worker and how it fixes the 'blocking' issue.</p>
</main>
<div>
<a href="./html/no-web-worker.html">Click here to start the demo!</a>
<p>*Note that it may take about 5-6 seconds for the page to render, and about 15-20 seconds on mobile.</p>
<p>*If you're on mobile, then it may take about 15-20 seconds. Just Take note that the page looks likes it's still loading, but really what's happening is the while loop is running.</p>
</div>
</body>
</html>