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.
I realise this is snark about the article going down, but it's actually a good point too. Not much point in optimising the client side if all your dynamic requests take a second for the server to process.
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".
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.
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.
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
[+] [-] jdwissler|13 years ago|reply
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.
[+] [-] addandsubtract|13 years ago|reply
[+] [-] dhruvbhatia|13 years ago|reply
[+] [-] robmil|13 years ago|reply
[+] [-] robmil|13 years ago|reply
[+] [-] byroot|13 years ago|reply
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
[+] [-] polshaw|13 years ago|reply
[+] [-] unknown|13 years ago|reply
[deleted]
[+] [-] sksksk|13 years ago|reply
[+] [-] unknown|13 years ago|reply
[deleted]
[+] [-] dreamdu5t|13 years ago|reply
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