Skip to content

Arthedian/webshim

 
 

Repository files navigation

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

Features

  • HTML5 shiv and innerShiv solution including basic CSS-support
  • canvas
  • HTML5 form features including: constraint validation and form widgets (input[type="range"], input[type="date"], input[type="number"], input[type="time"], input[type="month"], output, progress, input[list]/datalist)
  • HTML5 audio/video/track implementation
  • interactive elements: summary/details
  • JSON (stringify and parse)
  • localStorage/sessionStorage
  • geolocation
  • ECMAScript 5 / JavaScript 1.8.5 features

Installation and Usage

1 - Download the Webshim Lib and put the js-webshim-folder in your project.

2 - Include the JavaScript:

<script src="js/jquery.js"></script>

<!-- Simple change -->
<script src="js-webshim/minified/extras/modernizr-custom.js"></script> 

<!-- 'Use your own' variant -->
<script src="js/Modernizr-custom.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>

3 - 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.

License

The Webshims Lib core is licensed under the MIT-License.

Webshims Lib uses many great third party scripts:

Script License URL
flashcanvas MIT http://code.google.com/p/flashcanvas
flashcanvaspro closed http://flashcanvas.net
Jaris FLV GPL 3.0 http://jarisflvplayer.org
excanvas Apache License 2.0 http://excanvas.sourceforge.net
filereader MIT https://github.com/Jahdrien/FileReader
es5 MIT https://github.com/280north/narwhal
json-storage MIT https://gist.github.com/remy/350433
swfmini MIT https://code.google.com/p/swfobject
track BSD 2 clause https://github.com/cgiffard/Captionator
form-validators ??? https://sites.google.com/site/abapexamples/javascript/luhn-validation
color-picker MIT http://johndyer.name/post/2007/09/PhotoShop-like-JavaScript-Color-Picker.aspx
forms-picker MIT https://github.com/brandonaaron/jquery-mousewheel

Questions?

If you have any questions, please feel free to ask them on stackoverflow.com/questions/tagged/webshim.

Please tag your questions with 'webshim'.

About

Webshims Lib is a modular capability-based polyfill-loading library

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 95.5%
  • CSS 2.6%
  • Haxe 1.3%
  • PHP 0.5%
  • ActionScript 0.1%
  • Ruby 0.0%