Cara Membuat Sitemap Tabulasi

Cara Membuat Sitemap Tabulasi - Ficri Pebriyana

Cara Membuat Sitemap Tabulasi - Sitemap atau daftar isi sebuah blog memang begitu penting untuk kita pasang dalam sebuah web atau blog, hal ini dikarenakan sebuah sitemap sangat membantu para webmaster untuk mempermudah dalam pengenalan peta situs di dalam sebuah website. Dengan adanya sitemap, mesin google dengan mudah dapat menjelajahi dan meraih halaman - halaman yang ada didalamnya. Maka dengan ini google akan sangat mudah mengindex setiap halaman yang ada di blog kita, hasilnya SERP pada blog atau web Anda akan naik dan tampil di page one, asalkan di iringi dengan optimasi seo.

Jauh hari sebelumnya saya juga pernah membuat sebuah artikel mengenai sitemap yaitu Cara Membuat Sitemap Blog Keren Dengan jQuery, dengan penggunaan sitemap jquery mungkin terasa lebih panjang karena semua kategori dan postingan muncul secara bersamaan, berbeda dengan sitemap tabbed ini artikel yang muncul hanya label tertentu saja yang bisa kita atur dalam scriptnya. Tidak ada salahnya untuk mempercantik sebuah sitemap agar terlihat user frindly, oleh karena itu sitemap tab ini sangat cocok untuk di gunakan pada blog Anda. Untuk memasang daftar isi ini Anda bisa memilih apakah ingin menambahkan widget, laman, atau pada posting. Namun saya sarankan untuk membuatnya pada laman blog Anda, silahkan Anda simak tutorial membuat sitemap tabulasi dibawah ini :

1. Masuk ke Blogger.com
2. Klik pada Laman > Laman Baru
3. Berikan judul laman
4. Ganti Compose menjadi HTML
5. Copy dan Paste kode dibawah
6. Ganti http://www.ficripebriyana.com dengan URL/Link blog Anda
7. Klik Publikasikan

CSS
<style>
/* Skin for Blogger Tabbed Layout TOC */

#tabbed-toc {
  margin:0 auto;
  background-color:#2279A2;
  -webkit-box-shadow:0 1px 3px rgba(0,0,0,.4);
  -moz-box-shadow:0 1px 3px rgba(0,0,0,.4);
  box-shadow:0 1px 3px rgba(0,0,0,.4);
  overflow:hidden;
  position:relative;
  color:#333;
}

#tabbed-toc .loading {
  display:block;
  padding:5px 10px;
  font:normal bold 10px/normal Helmet,Freesans,Sans-Serif;
  color:white;
}

#tabbed-toc ul,
#tabbed-toc ol,
#tabbed-toc li {
  margin:0 0;
  padding:0 0;
  list-style:none;
}

#tabbed-toc .toc-tabs {
  width:20%;
  float:left;
}

#tabbed-toc .toc-tabs li a {
  display:block;
  font:normal bold 10px/28px Helmet,Freesans,Sans-Serif;
  height:28px;
  overflow:hidden;
  text-overflow:ellipsis;
  color:#ccc;
  text-transform:uppercase;
  text-decoration:none;
  padding:0 12px;
  cursor:pointer;
}

#tabbed-toc .toc-tabs li a:hover {
  background-color:#0D364B;
  color:white;
}

#tabbed-toc .toc-tabs li a.active-tab {
  background-color:#1F91C7;
  color:white;
  -webkit-box-shadow:-2px 2px 2px rgba(0,0,0,.5);
  -moz-box-shadow:-2px 2px 2px rgba(0,0,0,.5);
  box-shadow:-2px 2px 2px rgba(0,0,0,.5);
  position:relative;
  z-index:5;
  margin:0 -1px 0 0;
  /* cursor:text; */
}

#tabbed-toc .toc-content,
#tabbed-toc .divider-layer {
  width:80%;
  float:right;
  background-color:white;
  border-left:5px solid #1F91C7;
  -webkit-box-sizing:border-box;
  -moz-box-sizing:border-box;
  box-sizing:border-box;
}

#tabbed-toc .divider-layer {
  float:none;
  display:block;
  position:absolute;
  top:0;
  right:0;
  bottom:0;
  -webkit-box-shadow:0 0 7px rgba(0,0,0,.7);
  -moz-box-shadow:0 0 7px rgba(0,0,0,.7);
  box-shadow:0 0 7px rgba(0,0,0,.7);
}

#tabbed-toc .panel {
  position:relative;
  z-index:5;
  font:normal normal 10px/normal Helmet,Freesans,Sans-Serif;
}

#tabbed-toc .panel li a {
  display:block;
  position:relative;
  font-weight:bold;
  font-size:11px;
  color:#083146;
  line-height:20px;
  height:20px;
  padding:0 12px;
  text-decoration:none;
  outline:none;
  overflow:hidden;
}

#tabbed-toc .panel li time {
  display:block;
  font-style:italic;
  font-weight:normal;
  font-size:10px;
  color:#666;
  float:right;
}

#tabbed-toc .panel li .summary {
  display:block;
  padding:10px 12px 10px;
  font-style:italic;
  border-bottom:4px solid #1F91C7;
  overflow:hidden;
}

#tabbed-toc .panel li .summary img.thumbnail {
  float:left;
  display:block;
  margin:0 8px 0 0;
  padding:4px 4px;
  width:72px;
  height:72px;
  border:1px solid #dcdcdc;
  background-color:#fafafa;
}

#tabbed-toc .panel li:nth-child(even) {
  background-color:#EDF9FF;
}

#tabbed-toc .panel li a:hover,
#tabbed-toc .panel li a:focus,
#tabbed-toc .panel li a:hover time,
#tabbed-toc .panel li.bold a {
  background-color:#333;
  color:white;
  outline:none;
}

#tabbed-toc .panel li.bold a:hover,
#tabbed-toc .panel li.bold a:hover time {
  background-color:#222;
}

@media (max-width:700px) {
  #tabbed-toc {
    border:2px solid #333;
  }
  #tabbed-toc .toc-tabs,
  #tabbed-toc .toc-content {
    overflow:hidden;
    width:auto;
    float:none;
    display:block;
  }
  #tabbed-toc .toc-tabs li {
    display:inline;
    float:left;
  }
  #tabbed-toc .toc-tabs li a,
  #tabbed-toc .toc-tabs li a.active-tab {
    background-color:#2279A2;
    -webkit-box-shadow:2px 0 7px rgba(0,0,0,.4);
    -moz-box-shadow:2px 0 7px rgba(0,0,0,.4);
    box-shadow:2px 0 7px rgba(0,0,0,.4);
  }
  #tabbed-toc .toc-tabs li a.active-tab {
    background-color:white;
    color:#333;
  }
  #tabbed-toc .toc-content {
    border:none;
  }
  #tabbed-toc .divider-layer,
  #tabbed-toc .panel li time {
    display:none;
  }
}
</style>

HTML
<div id="tabbed-toc">
<span class="loading">Memuat...</span></div>
<script>
var tabbedTOC = {
    blogUrl: "http://www.ficripebriyana.com", // Blog URL
    containerId: "tabbed-toc", // Container ID
    activeTab: 1, // The default active tab index (default: the first tab)
    showDates: false, // `true` to show the post date
    showSummaries: false, // `true` to show the posts summaries
    numChars: 200, // Number of summary chars
    showThumbnails: false, // `true` to show the posts thumbnails (Not recommended)
    thumbSize: 40, // Thumbnail size
    noThumb: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAA3NCSVQICAjb4U/gAAAADElEQVQImWOor68HAAL+AX7vOF2TAAAAAElFTkSuQmCC", // A "no thumbnail" URL
    monthNames: [ // Array of month names
        "Januari",
        "Februari",
        "Maret",
        "April",
        "Mei",
        "Juni",
        "Juli",
        "Agustus",
        "September",
        "Oktober",
        "November",
        "Desember"
    ],
    newTabLink: true, // Open link in new window?
    maxResults: 99999, // Maximum post results
    preload: 0, // Load the feed after 0 seconds (option => time in milliseconds || "onload")
    sortAlphabetically: true, // `false` to sort posts by published date
    showNew: 7, // `false` to hide the "New !" mark in most recent posts, or define how many recent posts are to be marked
    newText: " - <em style='color:red;'>New !</em>" // HTML for the "New !" text
};
</script>

JavaScript
<script type="text/javascript">
var tabbedTOC_defaults = {
 blogUrl: "http://www.ficripebriyana.com", // Blog URL
 containerId: "tabbed-toc", // Container ID
 activeTab: 1, // The default active tab index (default: the first tab)
 showDates: false, // true to show the post date
 showSummaries: false, // true to show the posts summaries
 numChars: 200, // Number of summary chars
 showThumbnails: false, // true to show the posts thumbnails (Not recommended)
 thumbSize: 40, // Thumbnail size
 noThumb: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAA3NCSVQICAjb4U/gAAAADElEQVQImWOor68HAAL+AX7vOF2TAAAAAElFTkSuQmCC", // No thumbnail URL
 monthNames: [ // Array of month names
  "Januari",
  "Februari",
  "Maret",
  "April",
  "Mei",
  "Juni",
  "Juli",
  "Agustus",
  "September",
  "Oktober",
  "November",
  "Desember"
 ],
 newTabLink: true, // Open link in new window?
 maxResults: 99999, // Maximum posts result
 preload: 0, // Load the feed after 0 seconds (option => time in milliseconds || "onload")
 sortAlphabetically: true, // `false` to sort posts by date
 showNew: false, // `false` to hide the "New !" mark in most recent posts, or define how many recent posts are to be marked
 newText: " - <em style='color:red;'>Baru !</em>" // HTML for the "New !" text
};

for (var i in tabbedTOC_defaults) {
 tabbedTOC_defaults[i] = (typeof(tabbedTOC[i]) !== undefined && typeof(tabbedTOC[i]) !== 'undefined') ? tabbedTOC[i] : tabbedTOC_defaults[i];
}

function clickTab(pos) {
 var a = document.getElementById(tabbedTOC_defaults.containerId),
  b = a.getElementsByTagName('ol'),
  c = a.getElementsByTagName('ul')[0],
  d = c.getElementsByTagName('a');
 for (var t = 0; t < b.length; t++) {
  b[t].style.display = "none";
  b[parseInt(pos, 10)].style.display = "block";
 }
 for (var u = 0; u < d.length; u++) {
  d[u].className = "";
  d[parseInt(pos, 10)].className = "active-tab";
 }
}

function showTabs(json) {

 var total = parseInt(json.feed.openSearch$totalResults.$t,10),
  c = tabbedTOC_defaults,
  entry = json.feed.entry,
  category = json.feed.category,
  skeleton = "",
  newPosts = [];

 for (var g = 0; g < (c.showNew === true ? 5 : c.showNew); g++) {
  if (g == entry.length) break;
  entry[g].title.$t = entry[g].title.$t + (c.showNew !== false ? c.newText : '');
 }

 entry = c.sortAlphabetically ? entry.sort(function(a,b) {
  return (a.title.$t.localeCompare(b.title.$t));
 }) : entry;
 category = c.sortAlphabetically ? category.sort(function(a,b) {
  return (a.term.localeCompare(b.term));
 }) : category;

 // Build the tabs skeleton
 skeleton = '<span class="divider-layer"></span><ul class="toc-tabs">';
 for (var h = 0, cen = category.length; h < cen; h++) {
  skeleton += '<li class="toc-tab-item-' + h + '"><a href="javascript:clickTab(' + h + ');" title="'+ category[h].term +'">' + category[h].term + '</a></li>
';
 }
 skeleton += '</ul>
';

 // Bulid the tabs contents skeleton
 skeleton += '<div class="toc-content">
';
 for (var i = 0, cnt = category.length; i < cnt; i++) {
  skeleton += '<ol class="panel" data-category="' + category[i].term + '"';
  skeleton += (i != (c.activeTab-1)) ? ' style="display:none;"' : '';
  skeleton += '>';
  for (var j = 0; j < total; j++) {
   if (j == entry.length) break;
   var link, entries = entry[j],
    pub = entries.published.$t, // Get the post date
    month = c.monthNames, // Month array from the configuration
    title = entries.title.$t, // Get the post title
    summary = ("summary" in entries && c.showSummaries === true) ? entries.summary.$t.replace(/<br ?\/?>/g," ").replace(/<.*?>/g,"").replace(/[<>]/g,"").substring(0,c.numChars) + '&hellip;' : '', // Get the post summary
    img = ("media$thumbnail" in entries && c.showThumbnails === true) ? '<img class="thumbnail" style="width:'+c.thumbSize+'px;height:'+c.thumbSize+'px;" alt="" src="' + entries.media$thumbnail.url.replace(/\/s72(\-c)?\//,"/s"+c.thumbSize+"-c/") + '"/>' : '<img class="thumbnail" style="width:'+c.thumbSize+'px;height:'+c.thumbSize+'px;" alt="" src="' + c.noThumb.replace(/\/s72(\-c)?\//,"/s"+c.thumbSize+"-c/") + '"/>', // Get the post thumbnail
    cat = (entries.category) ? entries.category : [], // Post categories
    date = (c.showDates) ? '<time datetime="' + pub + '" title="' + pub + '">' + pub.substring(8,10) + ' ' + month[parseInt(pub.substring(5,7),10)-1] + ' ' + pub.substring(0,4) + '</time>' : ''; // Formated published date
    
   for (var k = 0; k < entries.link.length; k++) {
    if (entries.link[k].rel == 'alternate') {
     link = entries.link[k].href; // Get the post URL
     break;
    }
   }
   for (var l = 0, check = cat.length; l < check; l++) {
    var target = (c.newTabLink) ? ' target="_blank"' : ''; // Open link in new window?
    // Write the list skeleton only if at least one of the post...
    // ... has the same category term with one of the current categories term list
    if (cat[l].term == category[i].term) {
     skeleton += '<li title="' + cat[l].term + '"';
     skeleton += (c.showSummaries) ? ' class="bold"' : '';
     skeleton += '><a href="' + link + '"' + target + ' title="'+title+'">' + title + date + '</a>';
     skeleton += (c.showSummaries) ? '<span class="summary">' + img + summary + '<span style="display:block;clear:both;"></span></span>' : '';
     skeleton += '</li>
';
    }
   }
  }
  skeleton += '</ol>
';
 }

 skeleton += '</div>
';
 skeleton += '<div style="clear:both;">
</div>
';
 document.getElementById(c.containerId).innerHTML = skeleton;
 clickTab(c.activeTab-1);

}

(function() {
 var h = document.getElementsByTagName('head')[0],
  s = document.createElement('script');
  s.type = 'text/javascript';
  s.src = tabbedTOC_defaults.blogUrl + '/feeds/posts/summary?alt=json-in-script&max-results=' + tabbedTOC_defaults.maxResults + '&orderby=published&callback=showTabs';
 if (tabbedTOC_defaults.preload !== "onload") {
  setTimeout(function() {
   h.appendChild(s);
  }, tabbedTOC_defaults.preload);
 } else {
  window.onload = function() {
   h.appendChild(s);
  };
 }
})();
</script>

Note : Masukkan semua kode CSS, HTML, dan JavaScript diatas dalam satu laman.

Pengaturan Lanjutan

OpsiKeterangan
blogUrlGanti dengan URL/Link blog Anda.
containerIdID elemen yang akan digunakan sebagai penampung JSON yang sudah diproses (abaikan jika tidak perlu).
activeTabDigunakan untuk menentukan nomor urut tab yang aktif (nilai 1 akan membuat tab paling atas aktif).
showDatesGanti nilainya menjadi true untuk menampilkan waktu terbit posting.
showSummariesGanti nilainya menjadi true untuk menampilkan ringkasan posting.
showThumbnailsGanti nilainya menjadi true untuk menampilkan thumbnail posting (tidak direkomendasikan karena akan memperlambat loading laman).
thumbSizeDigunakan untuk menentukan ukuran thumbnail/image.
noThumbURL/Link gambar cadangan untuk posting yang tidak memiliki gambar di dalamnya.
monthNamesDigunakan untuk menentukan nama-nama bulan sesuai dengan sistem penanggalan di negara tempat Anda tinggal.
newTabLinkJika bernilai true, semua tautan akan membuka di tab/jendela baru saat diklik.
maxResultsJumlah maksimal posting yang akan ditampilkan.
preloadDigunakan untuk menentukan waktu penundaan pemuatan JSON. Gunakan satuan milidetik atau cukup tuliskan "onload" agar widget ini memuat setelah keseluruhan halaman telah selesai termuat.
sortAlphabeticallyfalse untuk menyortir posting secara normal berdasarkan bulan terbit, true untuk menyortir posting berdasarkan alfabet.
showNewfalse untuk menyembunyikan tanda New !. Ganti dengan angka untuk menentukan berapa banyak posting terbaru yang ingin ditandai dengan label New !.
newTextMarkup HTML bebas untuk membuat label New ! pada posting-posting terbaru.

Thanks to DTE

Sekian artikel mengenai Cara Membuat Sitemap Tabulasi. Kurang lebihnya mohon maaf. Semoga Bermanfaat...

Update 24 Desember 2017

Gunakan kode dibawah ini :
<link rel="stylesheet" href="//cdn.rawgit.com/tovic/dte-project/2fd2d2971c3398029ea5e149696447243e7f4d94/tabbed-toc.min.css"/>
<div id="tabbed-toc" class="tabbed-toc"><span class="loading">Memuat&hellip;</span></div>
<script>
var tabbedTOC = {
    blogUrl: "http://www.ficripebriyana.com/", // Blog URL
    containerId: "tabbed-toc", // Container ID
    activeTab: 1, // The default active tab index (default: the first tab)
    showDates: false, // `true` to show the post date
    showSummaries: false, // `true` to show the posts summaries
    numChars: 200, // Number of summary chars
    showThumbnails: false, // `true` to show the posts thumbnails (Not recommended)
    thumbSize: 40, // Thumbnail size
    noThumb: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAA3NCSVQICAjb4U/gAAAADElEQVQImWOor68HAAL+AX7vOF2TAAAAAElFTkSuQmCC", // A "no thumbnail" URL
    monthNames: [ // Array of month names
        "Januari",
        "Februari",
        "Maret",
        "April",
        "Mei",
        "Juni",
        "Juli",
        "Agustus",
        "September",
        "Oktober",
        "November",
        "Desember"
    ],
    newTabLink: true, // Open link in new window?
    maxResults: 99999, // Maximum post results
    preload: 0, // Load the feed after 0 seconds (option => time in milliseconds || "onload")
    sortAlphabetically: true, // `false` to sort posts by published date
    showNew: 7, // `false` to hide the "New!" mark in most recent posts, or define how many recent posts are to be marked
    newText: ' &ndash; <em style="color:red;">New!</em>' // HTML for the "New!" text
};
</script>
<script src="//cdn.rawgit.com/tovic/dte-project/2fd2d2971c3398029ea5e149696447243e7f4d94/tabbed-toc.min.js"></script>
Ganti http://www.ficripebriyana.com/ dengan URL blog Anda.

9 Responses to "Cara Membuat Sitemap Tabulasi"

  1. keren banget gan artikelnya terimah kasih sudah berbagi gan :D
    keep share gan (Y)

    ReplyDelete
  2. Bagus gan (y) boleh dicobak ini :D

    ReplyDelete
  3. Wah lengkap penjelasannya, ijin coba gan, thank you buat sharingnya

    ReplyDelete
  4. Hehehehe...sebenarnya gak butuh buat blog gue :P ,tapi buat latihan desain,gue coba aja dah |o|
    *Izin copas Codenya :P

    ReplyDelete
    Replies
    1. silahkan di coba sitemapnya biar keren blognya, wkwkwk :D

      Delete
  5. Izin copas yang bangg,, keren dah :D

    ReplyDelete
  6. kok gak muncul yak,cuman "memuat..." aja

    ReplyDelete
    Replies
    1. coba pasang kode jQuerynya, bisa copy kode dibawah ini, simpan sebelum kode </head>
      <script type='text/javascript'>
      //<![CDATA[
      if (typeof(jQuery) == 'undefined') {
      //output the script (load it from google api)
      document.write("<scr" + "ipt type=\"text/javascript\" src=\"http://ajax.googleapis.com/ajax/libs/jquery/1.8.1/jquery.min.js\"></scr" + "ipt>");
      }
      //]]>
      </script>

      Delete

Jika Ingin Memasukan Kode Script (CSS, HTML, JavaScript) Silahkan Gunakan Kode Dibawah ini :

1. Untuk Menyisipkan Kode Panjang Gunakan <i rel="pre">Kode Disini</i>
2. Untuk Menyisipkan Kode Pendek Gunakan <i rel="code">Kode Disini</i>
3. Untuk Menyisipkan Quote Gunakan <b rel="quote">Catatan Anda</b>
4. Untuk Menyisipkan Gambar Gunakan <i rel="image">URL Gambar</i>
5. Untuk Menyisipkan Video Gunakan <i rel="youtube">URL Video Youtube</i>

Iklan Atas Artikel

Iklan Tengah Artikel 1

Iklan Tengah Artikel 2

Iklan Bawah Artikel