Webshims Lib - The polyfilling, capability based loading JavaScript Library
General Principles:
- HTML5 compliant: correctly and accurately implemented (HTML5) Markup-, JS- and DOM-APIs
- capability based loading: extremely lightweight in modern browsers
- cross-browser support: All A-Graded browsers including latest version of Opera are tested
- extendable: if we have not implemented a feature you want, you can easily implement it on your own
Implemented Features:
- HTML5 shiv and innerShiv solution including basic CSS-support
- canvas
- HTML5 form features including: constraint validation and form widgets (input[range], input[date], input[time], input[datetime-local], output, input[list]/datalist)
- HTML5 audio/video implementation
- interactive elements: summary/details
- JSON (stringify and parse)
- localStorage/sessionStorage
- geolocation
- ECMAScript 5 / JavaScript 1.8.5 features
- Simply download Webshims Lib and put the js-webshim-folder in your project
- Include the JavaScript:
<script src="js/jquery.js"></script>
<script src="js/Modernizr-yepnope.js"></script>
<script src="js-webshim/minified/polyfiller.js"></script>
<script>
//load and implement all unsupported features
$.webshims.polyfill();
//or only load a specific feature
//$.webshims.polyfill('geolocation json-storage');
</script>
- Wait till everything has been loaded and then use it:
<script>
$(function(){
//work with JSON and localStorage
var userData = JSON.parse(localStorage.getItem('userData')) || {visits: 0};
$('#visits').html(userData.visits);
//...
});
</script>
More information and demos here.
The Webshims Lib core is licensed under the MIT-License. Note: Webshims Lib uses many great third party scripts.
If you have any questions, please feel free to ask them on the Using jQuery Plugins forum.
Please tag your questions with 'webshims' or 'polyfill'.
- much improved bug detection for buggy interactive constraint validation (no more assumptions)
- new custom event changedvaliditystate for forms feature
- improved overlay placement (errormessage/datalist)
- improved network performance
- polyfiller supports AMD + async pre-configuration
- Opera bugfix
- chrome/webkit fixes
- full compatibility with jQuery 1.7
- added locales for errormessages (If you want to improve existing messages or add some errormessages, please send me a pull request or file an issue)
- improved progress event for older Safari mobile and Firefox
- improved mediaelement (canplaythrough event, http live streaming for iOS)
- moved input[list]/datalist support from 'forms' to 'forms-ext' feature (more lightweight for Chrome/Safari)
- improved styleability of errorbubble
compatibility with jQuery 1.7 (1.8.1 is not compatible with jQuery 1.7)
- improved mediaelement loading
- fixed small bugs in mediaelement polyfill
- prepare for jQuery 1.7 compatibility
- fixed demos
- first mediaelement implementation (audio/video)
- implemented form submitter attributes (formaction, formtarget, formenctype)
- better language support
- updated es5-shim
- updated jQuery UI path
- fixed label for output element