Toggle Klapp Menü

De hier benutzte Code


   
  <style>
      
html, body {

    -webkit-font-smoothing: antialiased;
    -moz-font-smoothing: antialiased;

    background: #ffffff;
    background: -moz-radial-gradient(center, ellipse cover,  #ffffff 0%, #ffffff 26%, #f5f5f5 59%, #f5f5f5 77%, #cecece 100%);
    background: -webkit-gradient(radial, center center, 0, center center, 100%, color-stop(0%,#ffffff), color-stop(26%,#ffffff), color-stop(59%,#f5f5f5), color-stop(77%,#f5f5f5), color-stop(100%,#cecece));
    background: -webkit-radial-gradient(center, ellipse cover,  #ffffff 0%,#ffffff 26%,#f5f5f5 59%,#f5f5f5 77%,#cecece 100%);
    background: -o-radial-gradient(center, ellipse cover,  #ffffff 0%,#ffffff 26%,#f5f5f5 59%,#f5f5f5 77%,#cecece 100%);
    background: -ms-radial-gradient(center, ellipse cover,  #ffffff 0%,#ffffff 26%,#f5f5f5 59%,#f5f5f5 77%,#cecece 100%);
    background: radial-gradient(ellipse at center,  #ffffff 0%,#ffffff 26%,#f5f5f5 59%,#f5f5f5 77%,#cecece 100%);
    font-family: 'Days One', sans-serif;
    overflow: hidden;
    padding: 0;
    margin: 0;
    height: 100%;
}

body:before {

    background-image: url();
    position: absolute;
    content: '';
    opacity: 0.8;
    height: 100%;
    width: 100%;
    left: 0;
    top: 0;
}

a {

    transition: all 250ms cubic-bezier(0.230, 1.000, 0.320, 1.000);

    text-decoration: none;
}

.header {

    text-align: center;
    position: absolute;
    color: #333;
    width: 100%;
    top: 9%;
}

.header h1 {

    letter-spacing: -1px;
    text-shadow: -2px -1px 1px #fff, 1px 2px 2px rgba(0, 0, 0, 0.2);
    font-weight: 300;
    font-size: 36px;
    margin: 0;
}

.header h2 {

    text-transform: uppercase;
    text-shadow: -2px -1px 1px #fff, 1px 1px 1px rgba(0, 0, 0, 0.15);
    font-weight: 300;
    font-size: 12px;
    color: rgba(0,0,0,0.7);
    margin: 0;
}

.demo:after {

    box-shadow: 0 1px 16px rgba(0,0,0,0.15);
    background: #1b1b1b;
    position: absolute;
    content: '';
    height: 10px;
    width: 100%;
    top: 0;
}

/* List styles */

.list {

    transform-style: preserve-3d;
    
    text-transform: uppercase;
    position: absolute;
    margin-left: -140px;
    margin-top: -280px;
    top: 55%;
}

.list a {
    
    display: block;
    color: #fff;
}

.list a:hover {
    text-indent: 20px;
}

.list dt, .list dd {

    text-indent: 10px;
    line-height: 55px;
    background: #E0FBAC;
    margin: 0;
    height: 55px;
    width: 270px;
    color: #fff;
}

.list dt {

    transform: translateZ(0.3px);

    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2);
    font-size: 15px;
}

.list dd {

    border-top: 1px dashed rgba(255,255,255,0.3);
    line-height: 35px;
    font-size: 11px;
    height: 35px;
    margin: 0;
}

/* UI */

.toggle {

    box-shadow: 0 1px 4px rgba(0,0,0,0.15);
    border-radius: 3px;

    text-transform: uppercase;
    letter-spacing: -1px;
    line-height: 50px;
    margin-left: -70px;
    margin-top: -20px;
    background: #2b2b2b;
    text-align: center;
    font-size: 12px;
    position: absolute;
    height: 50px;
    bottom: 10%;
    width: 140px;
    color: #fff;
    left: 50%;
}

.toggle:hover {
    
    background: #E42692;
}




.sashimi dt, .sashimi dd, .sashimi a { background: #73C8A9; }
.nigiri dt, .nigiri dd, .nigiri a { background: #E32551; }
.maki dt, .maki dd, .maki a { background: #FFC219; }

.sashimi a:hover { background: #61c19e; }
.nigiri a:hover { background: #d31b46; }
.maki a:hover { background: #ffbb00; }

.nigiri {
    transform: perspective(1200px) rotateY(40deg) !important;
    transform-origin: 110% 25%;

    left: 20%;
}

.maki {
    transform: perspective(600px) translateZ(1px) !important;

    left: 50%;
}

.sashimi {
    transform: perspective(1200px) rotateY(-40deg) !important;
    transform-origin: -10% 25%;

    left: 80%;
}
  </style>




    <section class="demo">

        
Nigiri
Maguro
Sake
Unagi
Buri
Suzuki
Saba
Iwashi
Kohada
Hirame
Tobiwo
Maki
Ana-kyu
Chutoro
Kaiware
Kampyo
Kappa
Natto
Negitoro
Oshinko
Otoro
Tekka
Sashimi
Maguro
Toro
Ebi
Saba
Ika
Tako
Tomago
Kani
Katsuo
Maguro
Toggle </section> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script> <script> (function($) { // Global initialisation flag var initialized = false; // For detecting browser prefix and capabilities var element = document.createElement( 'div' ); var vendors = 'moz ms o webkit'.split( ' ' ); var toupper = function( str ) { return str.toUpperCase(); }; // Establish vendor prefix and CSS 3D support var vendor; for ( var prop, i = 0; i < vendors.length; i++ ) { prop = ( vendor = vendors[i] ) + 'Perspective'; if ( prop in element.style || prop.replace( /^(\w)/, toupper ) in element.style ) break; } var canRun = !!vendor; var prefix = '-' + vendor + '-'; var $this, $root, $base, $kids, $node, $item, $over, $back; var wait, anim, last; // Public API var api = { // Toggle open / closed toggle: function() { $this = $( this ); $this.makisu( $this.hasClass( 'open' ) ? 'close' : 'open' ); }, // Trigger the unfold animation open: function( speed, overlap, easing ) { // Cache DOM references $this = $(this); $root = $this.find( '.root' ); $kids = $this.find( '.node' ).not( $root ); // Establish values or fallbacks speed = utils.resolve( $this, 'speed', speed ); easing = utils.resolve( $this, 'easing', easing ); overlap = utils.resolve( $this, 'overlap', overlap ); $kids.each( function( index, el ) { // Establish settings for this iteration anim = 'unfold' + ( !index ? '-first' : '' ); last = index === $kids.length - 1; time = speed * ( 1 - overlap ); wait = index * time; // Cache DOM references $item = $( el ); $over = $item.find( '.over' ); // Element animation $item.css(utils.prefix({ 'transform': 'rotateX(180deg)', 'animation': anim + ' ' + speed + 's ' + easing + ' ' + wait + 's 1 normal forwards' })); // Shading animation happens when the next item starts if ( !last ) wait = ( index + 1 ) * time; // Shading animation $over.css(utils.prefix({ 'animation': 'unfold-over ' + (speed * 0.45) + 's ' + easing + ' ' + wait + 's 1 normal forwards' })); }); // Add momentum to the container $root.css(utils.prefix({ 'animation': 'swing-out ' + ( $kids.length * time * 1.4 ) + 's ease-in-out 0s 1 normal forwards' })); $this.addClass( 'open' ); }, // Trigger the fold animation close: function( speed, overlap, easing ) { // Cache DOM references $this = $(this); $root = $this.find( '.root' ); $kids = $this.find( '.node' ).not( $root ); // Establish values or fallbacks speed = utils.resolve( $this, 'speed', speed ) * 0.66; easing = utils.resolve( $this, 'easing', easing ); overlap = utils.resolve( $this, 'overlap', overlap ); $kids.each( function( index, el ) { // Establish settings for this iteration anim = 'fold' + ( !index ? '-first' : '' ); last = index === 0; time = speed * ( 1 - overlap ); wait = ( $kids.length - index - 1 ) * time; // Cache DOM references $item = $( el ); $over = $item.find( '.over' ); // Element animation $item.css(utils.prefix({ 'transform': 'rotateX(0deg)', 'animation': anim + ' ' + speed + 's ' + easing + ' ' + wait + 's 1 normal forwards' })); // Adjust delay for shading if ( !last ) wait = ( ( $kids.length - index - 2 ) * time ) + ( speed * 0.35 ); // Shading animation $over.css(utils.prefix({ 'animation': 'fold-over ' + (speed * 0.45) + 's ' + easing + ' ' + wait + 's 1 normal forwards' })); }); // Add momentum to the container $root.css(utils.prefix({ 'animation': 'swing-in ' + ( $kids.length * time * 1.0 ) + 's ease-in-out 0s 1 normal forwards' })); $this.removeClass( 'open' ); } }; // Utils var utils = { // Resolves argument values to defaults resolve: function( $el, key, val ) { return typeof val === 'undefined' ? $el.data( key ) : val; }, // Prefixes a hash of styles with the current vendor prefix: function( style ) { for ( var key in style ) { style[ prefix + key ] = style[ key ]; } return style; }, // Inserts rules into the document styles inject: function( rule ) { try { var style = document.createElement( 'style' ); style.innerHTML = rule; document.getElementsByTagName( 'head' )[0].appendChild( style ); } catch ( error ) {} }, keyframes: function( name, frames ) { var anim = '@' + prefix + 'keyframes ' + name + '{'; for ( var frame in frames ) anim += frame + '%' + '{' + prefix + frames[ frame ] + ';}'; utils.inject( anim + '}' ); } }; // Element templates var markup = { node: '', back: '', over: '' }; // Plugin definition $.fn.makisu = function( options ) { // Notify if 3D isn't available if ( !canRun ) { var message = 'Failed to detect CSS 3D support'; if( console && console.warn ) { // Print warning to the console console.warn( message ); // Trigger errors on elements this.each( function() { $( this ).trigger( 'error', message ); }); } return; } // Fires only once if ( !initialized ) { initialized = true; // Unfold utils.keyframes( 'unfold', { 0: 'transform: rotateX(180deg)', 50: 'transform: rotateX(-30deg)', 100: 'transform: rotateX(0deg)' }); // Unfold (first item) utils.keyframes( 'unfold-first', { 0: 'transform: rotateX(-90deg)', 50: 'transform: rotateX(60deg)', 100: 'transform: rotateX(0deg)' }); // Fold utils.keyframes( 'fold', { 0: 'transform: rotateX(0deg)', 100: 'transform: rotateX(180deg)' }); // Fold (first item) utils.keyframes( 'fold-first', { 0: 'transform: rotateX(0deg)', 100: 'transform: rotateX(-180deg)' }); // Swing out utils.keyframes( 'swing-out', { 0: 'transform: rotateX(0deg)', 30: 'transform: rotateX(-30deg)', 60: 'transform: rotateX(15deg)', 100: 'transform: rotateX(0deg)' }); // Swing in utils.keyframes( 'swing-in', { 0: 'transform: rotateX(0deg)', 50: 'transform: rotateX(-10deg)', 90: 'transform: rotateX(15deg)', 100: 'transform: rotateX(0deg)' }); // Shading (unfold) utils.keyframes( 'unfold-over', { 0: 'opacity: 1.0', 100: 'opacity: 0.0' }); // Shading (fold) utils.keyframes( 'fold-over', { 0: 'opacity: 0.0', 100: 'opacity: 1.0' }); // Node styles utils.inject( '.node {' + 'position: relative;' + 'display: block;' + '}'); // Face styles utils.inject( '.face {' + 'pointer-events: none;' + 'position: absolute;' + 'display: block;' + 'height: 100%;' + 'width: 100%;' + 'left: 0;' + 'top: 0;' + '}'); } // Merge options & defaults var opts = $.extend( {}, $.fn.makisu.defaults, options ); // Extract api method arguments var args = Array.prototype.slice.call( arguments, 1 ); // Main plugin loop return this.each( function () { // If the user is calling a method... if ( api[ options ] ) { return api[ options ].apply( this, args ); } // Store options in view $this = $( this ).data( opts ); // Only proceed if the scene hierarchy isn't already built if ( !$this.data( 'initialized' ) ) { $this.data( 'initialized', true ); // Select the first level of matching child elements $kids = $this.children( opts.selector ); // Build a scene graph for elements $root = $( markup.node ).addClass( 'root' ); $base = $root; // Process each element and insert into hierarchy $kids.each( function( index, el ) { $item = $( el ); // Which animation should this node use? anim = 'fold' + ( !index ? '-first' : '' ); // Since we're adding absolutely positioned children $item.css( 'position', 'relative' ); // Give the item some depth to avoid clipping artefacts $item.css(utils.prefix({ 'transform-style': 'preserve-3d', 'transform': 'translateZ(-0.1px)' })); // Create back face $back = $( markup.back ); $back.css( 'background', $item.css( 'background' ) ); $back.css(utils.prefix({ 'transform': 'translateZ(-0.1px)' })); // Create shading $over = $( markup.over ); $over.css(utils.prefix({ 'transform': 'translateZ(0.1px)' })); $over.css({ 'background': opts.shading, 'opacity': 0.0 }); // Begin folded $node = $( markup.node ).append( $item ); $node.css(utils.prefix({ 'transform-origin': '50% 0%', 'transform-style': 'preserve-3d', 'animation': anim + ' 1ms linear 0s 1 normal forwards' })); // Build display list $item.append( $over ); $item.append( $back ); $base.append( $node ); // Use as parent in next iteration $base = $node; }); // Set root transform settings $root.css(utils.prefix({ 'transform-origin': '50% 0%', 'transform-style': 'preserve-3d' })); // Apply perspective $this.css(utils.prefix({ 'transform': 'perspective(' + opts.perspective + 'px)' })); // Display the scene $this.append( $root ); } }); }; // Default options $.fn.makisu.defaults = { // Perspective to apply to rotating elements perspective: 1200, // Default shading to apply (null => no shading) shading: 'rgba(0,0,0,0.12)', // Area of rotation (fraction or pixel value) selector: null, // Fraction of speed (0-1) overlap: 0.6, // Duration per element speed: 0.8, // Animation curve easing: 'ease-in-out' }; $.fn.makisu.enabled = canRun; })( jQuery ); if ( $.fn.makisu.enabled ) { var $sashimi = $( '.sashimi' ); var $nigiri = $( '.nigiri' ); var $maki = $( '.maki' ); // Create Makisus $nigiri.makisu({ selector: 'dd', overlap: 0.85, speed: 1.7 }); $maki.makisu({ selector: 'dd', overlap: 0.6, speed: 0.85 }); $sashimi.makisu({ selector: 'dd', overlap: 0.2, speed: 0.5 }); // Open all $( '.list' ).makisu( 'open' ); // Toggle on click $( '.toggle' ).on( 'click', function() { $( '.list' ).makisu( 'toggle' ); }); // Disable all links $( '.demo a' ).click( function( event ) { event.preventDefault(); }); } else { $( '.warning' ).show(); } </script>