top | item 5584605

Make Your UI More Responsive with HTML5 Web Workers

42 points| johnrobinsn | 13 years ago |storminthecastle.com | reply

14 comments

order
[+] jdwissler|13 years ago|reply
If HTML 5/JS is going to become a serious platform for applications I think it is going to have to be able to leverage multiple threads/cores much more easily. I don't use Web Workers simply because they are too limited in scope in my opinion.

Sometimes I just want to search through my local data in my main thread to process 'n' numbers to show some result to the user and I don't want to lock up the DOM for 'n' milliseconds. I also don't want to make an entire new script file just for processing 'n' numbers, what if I need access to data in my main thread? Do I package 'n' numbers up and then send it as JSON? Well that can take more time then actually processing the numbers....and timers...such a hack.

I don't know all the design decisions behind web workers and I understand the safety of communicating with strings and events, but sometimes I really just want to call 'new Thread()' and have access to all my variables and data in my main thread. Yes it can be dangerous, yes you can fuck it up, but we still have that problem when we try to make our servers fast.

However, maybe I just don't understand how Web Workers work.

[+] robmil|13 years ago|reply
Unfortunately they're not supported in IE9 or below, which this article oddly fails to mention. So a more accurate title might be "make your UI more responsive for ~60% of your users with HTML5 web workers".
[+] byroot|13 years ago|reply
Browser marketshare is not a constant, it totally depends of your business. At my current job it's:

  - ~55% Chrome
  - ~35% Firefox
  - ~5% Safari
  - 1.5% IE 9+10
  - 1% Opera
So for us it make sense to use API even less supported than WebWorkers, like http://caniuse.com/pagevisibility

But if I was working for a chinese market place, or a bank intranet I'm sure it would be 80% IE6.

[+] Alphasite_|13 years ago|reply
I think this is the case for nearly every technology, new, or old, and although they wouldn't be amiss to mention it, 60% is a lot better than a lot of other techniques which get mentioned here.
[+] polshaw|13 years ago|reply
Sadly, can't even use it for cross-platform packaged apps (min requirement: chromium, iOS browser, android browser) because the android removed support after 2.1.
[+] sksksk|13 years ago|reply
There are a couple of polyfills available for Web Workers
[+] dreamdu5t|13 years ago|reply
What's a practical example of something that can't be done with proper evented programming, and has to be implemented using web workers?

If you need to perform CPU heavy calculations or processing of video/audio it just doesn't make sense to do it on the client even with web workers.

[+] leeoniya|13 years ago|reply
pdf.js uses background workers for parsing/processing pdf pages. really any other native format which could potentially js-processed for display in a browser directly