
A site map (or sitemap) is a list of pages of a web site accessible to crawlers or users. It can be either a document in any form used as a planning tool for Web design, or a Web page that lists the pages on a Web site, typically organized in hierarchical fashion.
To Add Sitemap Page To Blogger:
- Go to blogger dashboard
- Select your Blog
- Go to Pages > Create a New Page
- Switch from “Compose” to ” HTML”
- Paste the below given code in the HTML section and Publish it.
<div dir=”ltr” style=”text-align: left;” trbidi=”on”>
<style type=”text/css”>
#bp_toc {
color: #666;
margin: 0 auto;
padding: 0;
border: 1px solid #d2d2d2;
float: left;
width: 100%;
}
span.toc-note {
display: none;
}
#bp_toc tr:nth-child(2n) {
background: #f5f5f5;
}
td.toc-entry-col1 a {
font-weight: bold;
font-size: 14px;
}
.toc-header-col1,
.toc-header-col2,
.toc-header-col3 {
background:#9E9E9E;
}
.toc-header-col1 {
padding: 10px;
width: 250px;
}
.toc-header-col2 {
padding: 10px;
width: 75px;
}
.toc-header-col3 {
padding: 10px;
width: 125px;
}
.toc-header-col1 a:link,
.toc-header-col1 a:visited,
.toc-header-col2 a:link,
.toc-header-col2 a:visited,
.toc-header-col3 a:link,
.toc-header-col3 a:visited {
font-size: 13px;
text-decoration: none;
color: #fff;
font-weight: 700;
letter-spacing: 0.5px;
}
.toc-header-col1 a:hover,
.toc-header-col2 a:hover,
.toc-header-col3 a:hover {
text-decoration: none;
}
.toc-entry-col1,
.toc-entry-col2,
.toc-entry-col3 {
padding: 5px;
padding-left: 5px;
font-size: 12px;
}
.toc-entry-col1 a,
.toc-entry-col2 a,
.toc-entry-col3 a {
color: #666;
font-size: 13px;
text-decoration: none
}
.toc-entry-col1 a:hover,
.toc-entry-col2 a:hover,
.toc-entry-col3 a:hover {
text-decoration:underline;
}
#bp_toc table {
width: 100%;
margin: 0 auto;
counter-reset: rowNumber;
}
.toc-entry-col1 {
counter-increment: rowNumber;
}
#bp_toc table tr td.toc-entry-col1:first-child::before {
content: counter(rowNumber);
min-width: 1em;
min-height: 3em;
float: left;
border-right: 1px solid #fff;
text-align: center;
padding: 0px 11px 1px 6px;
margin-right: 15px;
}
td.toc-entry-col2 {
text-align: center;
}</style>
<br />
<div id=”bp_toc”>
<script type=”text/javascript”>
// —————————————————
// BLOGTOC
// —————————————————
// BlogToc creates a clickable Table Of Contents for
// Blogger Blogs.
// It uses the JSON post feed, and create a ToC of it.
// The ToC can be sorted by title or by date, both
// ascending and descending, and can be filtered by
// label.
// —————————————————
// Author: Satyendra Maurya
// Url: http://www.technogeekzone.com
// Version: 2
// Date: 2007-04-12
// —————————————————
// global arraysvar postTitle = new Array(); // array of posttitles
var postUrl = new Array(); // array of posturls
var postDate = new Array(); // array of post publish dates
var postSum = new Array(); // array of post summaries
var postLabels = new Array(); // array of post labels// global variables
var sortBy = “datenewest”; // default value for sorting ToC
var tocLoaded = false; // true if feed is read and ToC can be displayed
var numChars = 250; // number of characters in post summary
var postFilter = ”; // default filter value
var tocdiv = document.getElementById(“bp_toc”); //the toc container
var totalEntires =0; //Entries grabbed till now
var totalPosts =0; //Total number of posts in the blog.// main callback function
function loadtoc(json) {
function getPostData() {
// this functions reads all postdata from the json-feed and stores it in arrays
if (“entry” in json.feed) {
var numEntries = json.feed.entry.length;
totalEntires = totalEntires + numEntries;
totalPosts=json.feed.openSearch$totalResults.$t
if(totalPosts>totalEntires)
{
var nextjsoncall = document.createElement(‘script’);
nextjsoncall.type = ‘text/javascript’;
startindex=totalEntires+1;
nextjsoncall.setAttribute(“src”, “/feeds/posts/summary?start-index=” + startindex + “&max-results=500&alt=json-in-script&callback=loadtoc”);
tocdiv.appendChild(nextjsoncall);
}
// main loop gets all the entries from the feed
for (var i = 0; i < numEntries; i++) {
// get the entry from the feed
var entry = json.feed.entry[i];// get the posttitle from the entry
var posttitle = entry.title.$t;// get the post date from the entry
var postdate = entry.published.$t.substring(0,10);// get the post url from the entry
var posturl;
for (var k = 0; k < entry.link.length; k++) {
if (entry.link[k].rel == ‘alternate’) {
posturl = entry.link[k].href;
break;
}
}// get the post contents from the entry
// strip all html-characters, and reduce it to a summary
if (“content” in entry) {
var postcontent = entry.content.$t;}
else
if (“summary” in entry) {
var postcontent = entry.summary.$t;}
else var postcontent = “”;
// strip off all html-tags
var re = /<S[^>]*>/g;
postcontent = postcontent.replace(re, “”);
// reduce postcontent to numchar characters, and then cut it off at the last whole word
if (postcontent.length > numChars) {
postcontent = postcontent.substring(0,numChars);
var quoteEnd = postcontent.lastIndexOf(” “);
postcontent = postcontent.substring(0,quoteEnd) + ‘…’;
}// get the post labels from the entry
var pll = ”;
if (“category” in entry) {
for (var k = 0; k < entry.category.length; k++) {
pll += ‘<a href=”javascript:filterPosts(” + entry.category[k].term + ”);” title=”Click here to select all posts with label ” + entry.category[k].term + ””>’ + entry.category[k].term + ‘</a>, ‘;
}
var l = pll.lastIndexOf(‘,’);
if (l != -1) { pll = pll.substring(0,l); }
}// add the post data to the arrays
postTitle.push(posttitle);
postDate.push(postdate);
postUrl.push(posturl);
postSum.push(postcontent);
postLabels.push(pll);
}
}
if(totalEntires==totalPosts) {tocLoaded=true;showToc();}
} // end of getPostData// start of showtoc function body
// get the number of entries that are in the feed
// numEntries = json.feed.entry.length;// get the postdata from the feed
getPostData();// sort the arrays
sortPosts(sortBy);
tocLoaded = true;
}// filter and sort functions
function filterPosts(filter) {
// This function changes the filter
// and displays the filtered list of posts
// document.getElementById(“bp_toc”).scrollTop = document.getElementById(“bp_toc”).offsetTop;;
postFilter = filter;
displayToc(postFilter);
} // end filterPostsfunction allPosts() {
// This function resets the filter
// and displays all postspostFilter = ”;
displayToc(postFilter);
} // end allPostsfunction sortPosts(sortBy) {
// This function is a simple bubble-sort routine
// that sorts the postsfunction swapPosts(x,y) {
// Swaps 2 ToC-entries by swapping all array-elements
var temp = postTitle[x];
postTitle[x] = postTitle[y];
postTitle[y] = temp;
var temp = postDate[x];
postDate[x] = postDate[y];
postDate[y] = temp;
var temp = postUrl[x];
postUrl[x] = postUrl[y];
postUrl[y] = temp;
var temp = postSum[x];
postSum[x] = postSum[y];
postSum[y] = temp;
var temp = postLabels[x];
postLabels[x] = postLabels[y];
postLabels[y] = temp;
} // end swapPostsfor (var i=0; i < postTitle.length-1; i++) {
for (var j=i+1; j<postTitle.length; j++) {
if (sortBy == “titleasc”) { if (postTitle[i] > postTitle[j]) { swapPosts(i,j); } }
if (sortBy == “titledesc”) { if (postTitle[i] < postTitle[j]) { swapPosts(i,j); } }
if (sortBy == “dateoldest”) { if (postDate[i] > postDate[j]) { swapPosts(i,j); } }
if (sortBy == “datenewest”) { if (postDate[i] < postDate[j]) { swapPosts(i,j); } }
}
}
} // end sortPosts// displaying the toc
function displayToc(filter) {
// this function creates a three-column table and adds it to the screen
var numDisplayed = 0;
var tocTable = ”;
var tocHead1 = ‘POST TITLE’;
var tocTool1 = ‘Click to sort by title’;
var tocHead2 = ‘POST DATE’;
var tocTool2 = ‘Click to sort by date’;
var tocHead3 = ‘LABELS’;
var tocTool3 = ”;
if (sortBy == “titleasc”) {
tocTool1 += ‘ (descending)’;
tocTool2 += ‘ (newest first)’;
}
if (sortBy == “titledesc”) {
tocTool1 += ‘ (ascending)’;
tocTool2 += ‘ (newest first)’;
}
if (sortBy == “dateoldest”) {
tocTool1 += ‘ (ascending)’;
tocTool2 += ‘ (newest first)’;
}
if (sortBy == “datenewest”) {
tocTool1 += ‘ (ascending)’;
tocTool2 += ‘ (oldest first)’;
}
if (postFilter != ”) {
tocTool3 = ‘Click to show all posts’;
}
tocTable += ‘<table>’;
tocTable += ‘<tr>’;
tocTable += ‘<td class=”toc-header-col1″>’;
tocTable += ‘<a href=”javascript:toggleTitleSort();” title=”‘ + tocTool1 + ‘”>’ + tocHead1 + ‘</a>’;
tocTable += ‘</td>’;
tocTable += ‘<td class=”toc-header-col2″>’;
tocTable += ‘<a href=”javascript:toggleDateSort();” title=”‘ + tocTool2 + ‘”>’ + tocHead2 + ‘</a>’;
tocTable += ‘</td>’;
tocTable += ‘<td class=”toc-header-col3″>’;
tocTable += ‘<a href=”javascript:allPosts();” title=”‘ + tocTool3 + ‘”>’ + tocHead3 + ‘</a>’;
tocTable += ‘</td>’;
tocTable += ‘</tr>’;
for (var i = 0; i < postTitle.length; i++) {
if (filter == ”) {
tocTable += ‘<tr><td class=”toc-entry-col1″><a href=”‘ + postUrl[i] + ‘” title=”‘ + postSum[i] + ‘”>’ + postTitle[i] + ‘</a></td><td class=”toc-entry-col2″>’ + postDate[i] + ‘</td><td class=”toc-entry-col3″>’ + postLabels[i] + ‘</td></tr>’;
numDisplayed++;
} else {
z = postLabels[i].lastIndexOf(filter);
if ( z!= -1) {
tocTable += ‘<tr><td class=”toc-entry-col1″><a href=”‘ + postUrl[i] + ‘” title=”‘ + postSum[i] + ‘”>’ + postTitle[i] + ‘</a></td><td class=”toc-entry-col2″>’ + postDate[i] + ‘</td><td class=”toc-entry-col3″>’ + postLabels[i] + ‘</td></tr>’;
numDisplayed++;
}
}
}
tocTable += ‘</table>’;
if (numDisplayed == postTitle.length) {
var tocNote = ‘<span class=”toc-note”>Displaying all ‘ + postTitle.length + ‘ posts<br/></span>’; }
else {
var tocNote = ‘<span class=”toc-note”>Displaying ‘ + numDisplayed + ‘ posts labeled ”;
tocNote += postFilter + ” of ‘+ postTitle.length + ‘ posts total<br/></span>’;
}
tocdiv.innerHTML = tocNote + tocTable;
} // end of displayTocfunction toggleTitleSort() {
if (sortBy == “titleasc”) { sortBy = “titledesc”; }
else { sortBy = “titleasc”; }
sortPosts(sortBy);
displayToc(postFilter);
} // end toggleTitleSortfunction toggleDateSort() {
if (sortBy == “datenewest”) { sortBy = “dateoldest”; }
else { sortBy = “datenewest”; }
sortPosts(sortBy);
displayToc(postFilter);
} // end toggleTitleSortfunction showToc() {
if (tocLoaded) {
displayToc(postFilter);
var toclink = document.getElementById(“toclink”);
}
else { alert(“Just wait… TOC is loading”); }
}function hideToc() {
var tocdiv = document.getElementById(“toc”);
tocdiv.innerHTML = ”;
var toclink = document.getElementById(“toclink”);
toclink.innerHTML = ‘<a href=”#” onclick=”scroll(0,0); showToc(); Effect.toggle(‘+”‘toc-result’,’blind’);”+'”>» Show Table of Contents</a> <img src=”http://chenkaie.blog.googlepages.com/new_1.gif”/>’;
}
</script>
<script src=”/feeds/posts/summary?alt=json-in-script&max-results=9999&callback=loadtoc” type=”text/javascript”></script></div>
</div>
nice
i have followed your steps but i am unable to link sitemap into menu. Could you help me on this
hi,
Thank you for the above code.
I applied it to my blog, and added the following:
1- The blog information: Title, Author, Labels, Total Posts.
2- Count of words and Count of characters for each post.
3- The ability to sort the posts by length (count of words and count of characters), shortest first or longest first.
Thanks again.