reveal.js is a framework for easily creating beautiful presentations using HTML. You'll need a browser with support for CSS 3D transforms to see it in its full glory.
Slides can be nested inside of other slides, try pressing down.
 
						
					Press down or up to navigate.
Cornify
 
						
					That's it, time to go back up.
 
						
					Press ESC to enter the slide overview. Hold down alt and click on any element to zoom in on it using zoom.js. Alt + click anywhere to zoom back out.
If you don't like writing slides in HTML you can use the online editor rvl.io.
Try it out! You can swipe through the slides and pinch your way to the overview.
						You can select from different transitions, like: 
						Cube -
						Page -
						Concave -
						Linear
					
						Reveal.js comes with a few themes built in: 
						Sky -
						Beige -
						Simple -
						Serif -
						Default
					
						
							* Theme demos are loaded after the presentation which leads to flicker. In production you should load your theme in the <head> using a <link>.
						
					
							Set data-state="something" on a slide and "something"
							will be added as a class to the document element when the slide is open. This lets you
							apply broader style changes, like switching the background.
						
 
						
					 
						
					 
						
					
						Additionally custom events can be triggered on a per slide basis by binding to the data-state name.
					
Reveal.addEventListener( 'customevent', function() {
	console.log( '"customevent" has fired' );
} );
					
						These guys come in two forms, inline: 
						The nice thing about standards is that there are so many to choose from
 and block:
					
For years there has been a theory that millions of monkeys typing at random on millions of typewriters would reproduce the entire works of Shakespeare. The Internet has proven this theory to be untrue.
function linkify( selector ) {
  if( supports3DTransforms ) {
    
    var nodes = document.querySelectorAll( selector );
    for( var i = 0, len = nodes.length; i < len; i++ ) {
      var node = nodes[i];
      if( !node.className ) ) {
        node.className += ' roll';
      }
    };
  }
}
					Courtesy of highlight.js.
You can link between slides internally, like this.
Hit the next arrow...
... to step through ...
any type 
					
				Presentations can be exported to PDF, below is an example that's been uploaded to SlideShare.
Press b or period on your keyboard to enter the 'paused' mode. This mode is helpful when you want to take disctracting slides off the screen during a presentation.
reveal.js and rvl.io are entirely free but if you'd like to support the projects you can donate below. Donations will go towards hosting and domain costs.