Menyediakan informasi seputar perkembangan mesin Blogger dan internet secara umum.

Menciptakan Navigasi Mini Bergaya Nettuts+

Tuts+ Navigation
http://tutsplus.com

Saat Anda mengunjungi situs Nettuts+, atau Tuts+ pasti Anda akan melihat sebuah menu melayang kecil di sebelah kiri layar. Kali ini Saya akan membuat versi yang mirip dengan itu. Pada dasarnya, cara kerjanya masih sama dengan jQuery Tooltip onClick, yaitu pada saat suatu elemen diklik, maka elemen tertentu yang telah ditentukan sebagai target akan tampil. Untuk menciptakan sedikit perbedaan, Saya telah menambahkan elemen tooltip dengan konten yang diproduksi dari teks di dalam menu:

$('#sidenav li a.main').hover(function() {
    $(this).append('<span class="ttp">' + $(this).text() + '<em></em></span>');
        $('span.ttp', this).stop().animate({marginLeft:7, opacity:"show"}, 200);
    }, function() {
        $('span.ttp', this).stop().animate({marginLeft:10, opacity:"hide"}, 100, function() {
            $(this).remove();
        });
    });
});
Menciptakan Navigasi Mini Bergaya Nettuts+

Lihat Demo Unduh Berkas

Kerangka Navigasi

Kerangka navigasi terdiri dari elemen biasa yaitu <nav>, <ul> dan <li>:

<nav id='sidenav'>
    <ul>
        <li><a class='main home' href='/'>Home</a></li>
        <li><a class='main about' href='#'>About</a>
            <ul class='fallback'>
                <li><a class='social blogger' href='#'>Me on Blogger</a></li>
                <li><a class='social facebook' href='#'>Me on Facebook</a></li>
                <li><a class='social twitter' href='#'>Me on Twitter</a></li>
                <li><a class='social googleplus' href='#'>Me on Google+</a></li>
            </ul>
        </li>
        <li><a class='main archive' href='#'>Archives</a>
            <ul class='fallback'>
                <li><a href='#'>Table of Contents</a></li>
                <li><a href='#'>Recent Articles</a></li>
                <li><a href='#'>Recent Comments</a></li>
            </ul>
        </li>
        <li><a class='main share' href='#'>Share</a>
            <ul class='fallback'>
                <li><a class='social blogger' href='#'>Blogger</a></li>
                <li><a class='social facebook' href='#'>Facebook</a></li>
                <li><a class='social twitter' href='#'>Twitter</a></li>
                <li><a class='social googleplus' href='#'>Google+</a></li>
                <li><a class='social flickr' href='#'>Flickr</a></li>
                <li><a class='social rss' href='#'>RSS</a></li>
                <li><a class='social mail' href='#'>Mail</a></li>
            </ul>
        </li>
        <li><a class='main photos' href='#'>Screencast</a></li>
        <li><a class='main contact' href='#'>Contact</a>
            <ul class='fallback' style='font-weight:bold;'>
                <li><a class='social facebook' href='#'>Facebook</a></li>
                <li><a class='social twitter' href='#'>Twitter</a></li>
                <li><a class='social mail' href='#'>Mail</a></li>
            </ul>
        </li>
    </ul>
</nav>

CSS

Kode CSS tidak begitu rumit, di sini Saya hanya menekankan kepada konsep CSS Sprites:

/*!
 * Mini floating Navigation by Taufik Nurrohman
 * Visit: http://gplus.to/tovic
 */

#sidenav {
  position:fixed !important;
  position:absolute; /* IE6 Fallback */
  top:60px;
  left:0px;
  z-index:999;
  background-color:#eee;
  border:1px solid #ccc;
  width:auto;
  height:auto;
  text-indent:-99999px;
  font:normal 12px Arial,Sans-Serif !important;
  -webkit-box-shadow:0px 1px 7px -3px rgba(0,0,0,0.4);
  -moz-box-shadow:0px 1px 7px -3px rgba(0,0,0,0.4);
  box-shadow:0px 1px 7px -3px rgba(0,0,0,0.4);
}

#sidenav ul {
  margin:0px 0px;
  padding:0px 0px;
}

#sidenav li {
  margin:0px 0px;
  padding:0px 0px;
  list-style:none;
  display:block;
  position:relative;
}

#sidenav a {
  display:block;
  width:20px;
  border-bottom:1px solid #ccc;
  color:#666;
  text-decoration:none;
  -webkit-box-shadow:inset 0px 0px 0px 1px white;
  -moz-box-shadow:inset 0px 0px 0px 1px white;
  box-shadow:inset 0px 0px 0px 1px white;
}

#sidenav li:last-child a {
  border-bottom:none;
}

#sidenav span.ttp {
  display:block;
  position:absolute;
  top:0px;
  font:normal 94% Arial,Sans-Serif;
  background-color:#39f;
  color:white;
  padding:0px 10px;
  line-height:22px;
  height:22px;
  width:auto;
  left:100%;
  z-index:77;
  margin-left:17px;
  text-indent:0px;
  -webkit-border-radius:5px;
  -moz-border-radius:5px;
  border-radius:5px;
  display:none;
}

#sidenav span.ttp em {
  display:block;
  width:0px;
  height:0px;
  border:4px solid transparent;
  border-right-color:#39f;
  position:absolute;
  top:7px;
  right:100%;
}

#sidenav li ul {
  width:150px;
  height:auto;
  background:transparent;
  border:none;
  position:absolute;
  top:-1px;
  left:100%;
  -webkit-box-shadow:0px 1px 7px -3px rgba(0,0,0,0.4);
  -moz-box-shadow:0px 1px 7px -3px rgba(0,0,0,0.4);
  box-shadow:0px 1px 7px -3px rgba(0,0,0,0.4);
  display:none;
}

#sidenav li ul a {  
  border:1px solid #ccc;
  border-bottom:none;
  background-color:#eee;
  display:block;
  width:auto;
  padding:0px 10px;
  line-height:25px;
  text-indent:0px;
  -webkit-box-shadow:inset 0px 0px 0px 1px white;
  -moz-box-shadow:inset 0px 0px 0px 1px white;
  box-shadow:inset 0px 0px 0px 1px white;
}

#sidenav li a:hover {background-color:#ddd;}

#sidenav li ul li:last-child a {
  border-bottom:1px solid #ccc;
}

/* CSS Sprites */
#sidenav a.main {
  background-image:url('main-sprites.png');
  background-repeat:no-repeat;
  width:26px;
  height:25px;
}

#sidenav a.home    {background-position:5px 4px;   }
#sidenav a.about   {background-position:5px -22px; }
#sidenav a.archive {background-position:5px -48px; }
#sidenav a.share   {background-position:5px -73px; }
#sidenav a.photos  {background-position:5px -100px;}
#sidenav a.contact {background-position:5px -126px;}

#sidenav li ul a.social {
  background-image:url('social-sprites.png');
  background-repeat:no-repeat;
  padding-left:30px !important;
}

#sidenav li ul a.blogger    {background-position:5px 4px;   }
#sidenav li ul a.facebook   {background-position:5px -21px; }
#sidenav li ul a.twitter    {background-position:5px -47px; }
#sidenav li ul a.googleplus {background-position:5px -73px; }
#sidenav li ul a.flickr     {background-position:5px -99px; }
#sidenav li ul a.rss        {background-position:5px -125px;}
#sidenav li ul a.mail       {background-position:5px -151px;}

/* CSS Fallback */
#sidenav li:hover .fallback {display:block;}

jQuery

Dan… sedikit kode jQuery yang merupakan pengembangan dari jQuery Tooltip onClick. Kodenya memang tampak banyak, tapi yang banyak itu pada dasarnya hanya deskripsi cara kerjanya saja:

$(function() {

    // Menonaktifkan fallback CSS (Saya akan membahas ini suatu saat nanti)
    $('#sidenav .fallback').removeClass('fallback');

    // Menampilkan dan menyembunyikan tooltip
    $('#sidenav li a.main').hover(function() {
        $(this).append('<span class="ttp">' + $(this).text() + '<em></em></span>');
        $('span.ttp', this).stop().animate({marginLeft:7, opacity:"show"}, 200);
    }, function() {
        $('span.ttp', this).stop().animate({marginLeft:10, opacity:"hide"}, 100, function() {
            $(this).remove();
        });
    });

    // Saat elemen <a> diklik...
    $('#sidenav li a[href="#"]').click(function(e) {
        // Hilangkan semua anak <ul> dan tooltip yang tampil
        $('#sidenav li ul:visible, span.ttp:visible').hide();
        // Tampilkan elemen setelahnya (dalam hal ini adalah elemen <ul>)
        // dengan efek .show('fast') dan set nilai margin-left menjadi 10 piksel untuk menciptakan jarak
        $(this).next().css('margin-left', '10px').show('fast');
        // Jangan biarkan event .click() pada elemen ini mempengaruhi elemen lain di dalam dokumen
        // Selengkapnya: http://api.jquery.com/event.stopPropagation/
        e.stopPropagation();
        return false;
    });

    // Hilangkan semua anak elemen <ul> dan tooltip yang tampil saat elemen selain menu diklik
    $(document).click(function() {
        $('#sidenav li ul:visible, span.ttp:visible').hide();
    });

});

Intinya adalah, saat sebuah menu diklik, maka anak menu di dalamnya akan tampil, sedangkan elemen sejenis lain yang sedang tampil akan menghilang, termasuk tooltip menu itu sendiri:

// Saat elemen <a> diklik...
$('#sidenav li a[href="#"]').click(function(e) {
    // Hilangkan semua anak <ul> dan tooltip yang tampil
    $('#sidenav li ul:visible, span.ttp:visible').hide();
    // Tampilkan elemen setelahnya (dalam hal ini adalah elemen <ul>)
    // dengan efek .show('fast') dan set nilai margin-left menjadi 10 piksel untuk menciptakan jarak
    $(this).next().css('margin-left', '10px').show('fast');
    // Jangan biarkan event .click() pada elemen ini mempengaruhi elemen lain di dalam dokumen
    // Selengkapnya: http://api.jquery.com/event.stopPropagation/
    e.stopPropagation();
    return false;
});

  

Berlangganan

Berlangganan: Dapatkan berbagai materi dan informasi seputar dunia pemrograman yang tidak akan pernah bisa kalian dapatkan di buku dan di bangku kuliah.

 12 Komentar

Memuat…

Tautan (link) hidup dalam komentar akan terhapus secara otomatis.
Untuk menyisipkan tautan dengan aman, gunakan kode [url=http://example.com]Teks Tautan[/url]
Untuk menyisipkan kode, gunakan tag <i rel="code">KODE ANDA</i>
Untuk menyisipkan gambar, gunakan kode [img]URL GAMBAR[/img]
Untuk menyisipkan judul, gunakan tag <b rel="h4">JUDUL ANDA DI SINI…</b>
Untuk menciptakan efek tebal gunakan tag <strong>TEKS ANDA DI SINI…</strong>
Untuk menciptakan efek huruf miring gunakan tag <em>TEKS ANDA DI SINI…</em>

Khusus untuk membalas komentar disarankan menggunakan tombol balas di samping komentar terkait dibandingkan menggunakan formulir komentar di bawah agar komunikasi lebih terstruktur. Karena mungkin, apa yang Anda tanyakan/katakan saat ini akan sangat bermanfaat bagi pembaca lain.

:) :( ^_^ :D ;) :bd :'( :\ ;p B) :Q :Ozzz 7:( \o/ **p :* 0:) :a 7:O *fuck* x& x@ ~x( *yaya* =p*

Nama Saya Taufik Nurrohman. Sebenarnya Saya tidak bisa disebut sebagai seorang yang profesional dalam bidang ini, karena Saya tidak menguasai bidang ini melalui pendidikan formal. Saya hanyalah seorang antusias. Dibandingkan sebagai seorang desainer atau pengembang, Saya lebih suka jika disebut sebagai seorang hobiis saja yang tertarik dengan dunia web.

Daftar Tautan

Saya tidak bisa hidup tanpa JavaScript! Aktifkan JavaScript?
Ke atas!