2015 - The JS1k hype train is real!
Competition rules 2015
Size limit is 1024
That is 1024 bytes, not characters. The server will enforce this.
So, to clear up some confusion here are some do's and don'ts:
- Network resources are strictly forbidden.
- Local file upload is out.
- No "copy/paste the contents of this pastebin into this field and press go" shenanigans.
- Allowed APIs:
Local File (for dynamic files/blobs),
(Mouse) Pointer Lock API,
- Also allowed but your demo may not depend on:
Webcam and Microphone (
- Disallowed APIs:
WebRTC / OpenRTC,
- ES6 is out.
Probably allowed next year.
- WebVR API demos do not compete :( But you may submit them, if they are feasible in 1k.
Must show something on its own
Your submission must at least have a visual cue (not console/library only) and should be capable of running on its own content. No white screen of death.
Additionally it may ask additional input to change some input parameters. Consider this; we want to prevent an image processing demo that shows a nearly blank screen unless you allow webcam access. It should reasonably act the same way when different input is given. If your demo effectively does nothing I will reject it. Judges are instructed to judge in a similar way.
Good examples: 1, 2, 3.
Bad examples: noop library, missing default, requires copy/paste.
Allowed: needs mouse hover (even though that won't work on mobile...)
Must work as is in the provided shim
There is one shim for all demos. It feats the following. ("optional" means you can configure it when submitting your demo)
body tag exposed in a global var
- a fullscreen
canvas element, tag and context exposed in a global var (optional)
- WebGL shim (same as last year) and 3d context (optional)
- demo restart function (
top.reload()), it's the same as pressing the button and will restart your demo.
- normalization of vendor prefixed API's (please notify me if something needs unprefixing/normalization)
May not escape the iframe
top.reload(). You're allowed to adjust the url hash as long as you don't reload the page.
Must be received before it is March 15th in CET
Form submission automatically closes
February 28th March 14th 2015, midnight CET (Central European Time, that's GMT+1). The deadline has been extended by 2 weeks! When in doubt remember this; if I'm in March 15th, you'll be too late ;)
Must work in at least two common desktop browsers
- And at least one of them must work under Linux
- Opera counts as Chrome (they are identical under the hood)
- In general your demo should just work across the board
- Must not need additional installations of plugins (so it should work "out of the box")
- Mobile support is not a requirement but it would be nice, no? Mobile only demo's are out.
- ES6 is out for this year, stick to ES5.
- If an HTML5 API needs un-prefixing tell me so I can add it to the shim
- Current browser versions: CH39, FX35, IE11, SF7, O27
Theme is optional
It is only a suggestion for inspiration. If you don't like the theme or had something else in mind by all means go for it.
One entry per person competes for a prize
You can submit multiple demos but only the last entry you submit can compete for prizes. The judges will not consider on older submissions. If you're submitting as a group please use a separate email and let me know about it (in the DM). The judges and myself may submit a demo but it will not compete for prizes.
When in doubt: I decide
And if it concerns an interpretation of the rules I will consult the judges on a verdict.