[Blogger] 樹狀分類
〈1〉修改範本 1. 如果尚未安裝「標籤」小工具,請先到後台安裝
2. 如果已經安裝完成,請先找到修改點
<b:widget id='Label1' locked='false' title='分類' type='Label'>
2.1 新增「展開」「收合」功能
找到這一行字
<h2><data:title/></h2>修改為
<h2><div id="treeLabel_toggle"></div><data:title/></h2>
2.2 新增樹狀分類
找到這一整段
<b:if cond='data:display == "list"'> <ul> <b:loop values='data:labels' var='label'> .... </b:loop> </ul> <b:else/> <b:loop values='data:labels' var='label'> ..... </b:loop> </b:if>修改為
<div id="treeLabel_main" style="font-family: Arial;"><span id="treeLabel_host" class="item-control blog-admin"></span></div> <style> #treeLabel_toggle { float: right; font-family: Arial; } #treeLabel_toggle a, #treeLabel_main a { font-size: 10pt; text-decoration: none; } .treeLabel_catText a:link { color: #0b5394; /* 請填入大分類的顏色, 如果要使用系統預設的超連結顏色, 可刪除此行 */ font-weight: bold; } .treeLabel_catText a:hover { color: #b8b832; /* 請填入滑鼠移過大分類要顯示的顏色, 如果要使用系統預設的超連結顏色, a:link 與 a:hover 的顏色都不要設定 */ } .treeLabel_category { /* 這裡可設定大分類名稱區塊的 CSS */ font-size: 10pt; margin-top: 4px; } .treeLabel_label { /* 這裡可設定標籤名稱區塊的 CSS */ font-size: 10pt; margin-top: 2px; } </style> <script> //<![CDATA[ var treeLabel = { category: ["電腦", "休閒", "閱讀"], // 雙引號內填入大分類名稱, 每個大分類用小寫逗號隔開, 最後一個大分類之後不可有逗號; 填入順序就是顯示的順序 showLevel: 2, // 預設打開的標籤層數, 填入 1 為全部收起的狀態 showCategoryCount: "Y", // 大分類若不顯示文章數, 請填入 "N" openLogo: "▼", // 如使用圖檔,雙引號內請填入 http 開頭的網址 closeLogo: "►", // 如使用圖檔,雙引號內請填入 http 開頭的網址 listLogo: "⇢", // 如使用圖檔,雙引號內請填入 http 開頭的網址 margin: 10, // 縮排的像素值 openText: "全展開", // 可改為自訂文字, 不顯示文字請改為 "" closeText: "全收合", // 可改為自訂文字, 不顯示文字請改為 " " interval: "Y" // 預設每個大分類之間空一行, 如不要空行請填 "N" }; //]]> treeLabel.data = []; treeLabel.labelName = []; <b:loop values='data:labels' var='label'> (function () { var a = "<data:label.name/>", b = a.split("-"), l = b.length, data = [], i; //<![CDATA[ for(i=0;i<l;i++){if(i!=0&&i!=l-1&&b[i].search(" ")!=0){b[i]=" "+b[i]}data[i]=b[i]}; //]]> treeLabel.data.push([data, "<data:blog.languageDirection/>", "<data:label.url/>", "<data:label.count/>"]); } )(); </b:loop> //<![CDATA[ treeLabel.dg=function(a){return document.getElementById(a)};treeLabel.toggle=function(n){var k=treeLabel.dg,o=treeLabel.labelName,b=o.length,p=treeLabel.openLogo,h=treeLabel.closeLogo,m,q,d,g,a,e,c,f;for(e=0;e<b;e++){m=o[e];f=m.length;for(c=0;c<f;c++){q=m.join("")+c;d="logo"+q;g=k(q);a=k(d);if(m[1]&&n==1){if(a&&!a.firstChild.src){a.innerHTML=p}if(a&&a.firstChild.src){a.firstChild.src=p}if(g){g.style.display="block"}}if(m[1]&&n==0){if(a&&!a.firstChild.src){a.innerHTML=h}if(a&&a.firstChild.src){a.firstChild.src=h}if(g){g.style.display="none"}}}}};treeLabel.swap=function(c,d){var f=treeLabel.dg,a=f(d),e=f(c),b=treeLabel.openLogo,g=treeLabel.closeLogo;if(!e.firstChild.src){e.innerHTML=(e.innerHTML==b)?g:b}else{e.firstChild.src=(e.firstChild.src==b)?g:b}a.style.display=(a.style.display=="block")?"none":"block"};(function(){var l=treeLabel.dg,S=treeLabel.data,F=treeLabel.category,R=[],D=[],u=[],f=[],z=F.length,g=S.length,E=treeLabel.showLevel,v=treeLabel.openLogo,e=treeLabel.closeLogo,N=treeLabel.listLogo,d=treeLabel.margin,I=(treeLabel.interval=="Y")?"<p/>":"",w="",t="",m="",a=0,J,A,o,c=l("treeLabel_host"),Q=(window.getComputedStyle)?(window.getComputedStyle(c).display=="none")?"<a href='http://wayne-fu.blogspot.com/2013/01/multi-tree-label-update.html' target='_blank'><img src='https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjVSFqdVHg4xUd0wiryF5sotVIOUF5VJXi7Me7cMMBuXNOtXTlbC0AkAFnjQufWv3WwvmQPTN0xkozZ3LaMVrl_uzOOkQeunXLfB-nQI3i7ufAtgGeowzKpZu9gOAI2_FSx7sBUxRC0nNdH/s1600/info.png' title='Blogger 多層樹狀標籤\n程式設計:WFU BLOG' style='width: 20px; vertical-align: middle;'/></a>":"":"",P,O,M,C,B,K,L,s,H,q,G,h,b,r;v=(v.search("http")<0)?v:"<img src='"+v+"' style='vertical-align: middle;'/>";e=(e.search("http")<0)?e:"<img src='"+e+"' style='vertical-align: middle;'/>";N=(N.search("http")<0)?N:"<img src='"+N+"' style='vertical-align: middle;'/>";S.sort();for(P=0;P<g;P++){treeLabel.labelName[P]=S[P][0];D[P]=S[P][1];u[P]=S[P][2];f[P]=S[P][3]}R=treeLabel.labelName;for(P=0;P<z;P++){for(O=0;O<g;O++){J=R[O];if(J[1]&&J[0]==F[P]){a++;if(a!=0){a=1}L=function(){if(O-1<0){return 0}K=0,A=R[O-1];function i(){if(J[K]==A[K]){K++;i()}}i();return K};M=L();o=function(){if(J[M+1]){H=0;q="";G=J.join("")+M;h="logo"+G;b=(M<E-1)?v:e;r=(M<E-1)?"block":"none";if(treeLabel.showCategoryCount=="Y"){for(C=0;C<g;C++){A=R[C];for(B=M;B>=0;B--){if(J[B]!=A[B]){break}if(J[B]==A[B]&&B==0){H+=parseInt(f[C]);q="("+H+")"}}}}w+="<div class='treeLabel_category'><span onclick='treeLabel.swap(\""+h+'","'+G+"\");'><a id='"+h+"' href='javascript:' style='margin-left:"+M*d+"px;'>"+b+"</a>";w+="<span class='treeLabel_catText'><a href='javascript:'> "+J[M]+" </a></span></span><span>"+q+"</span></div><div id='"+G+"' style='display:"+r+"'>";M++;o()}else{w+="<div class='treeLabel_label' style='margin-left:"+M*d+"px;'>"+N+" <a dir='"+D[O]+"' href='"+u[O]+"'><span dir='ltr'>"+J[M]+"</span></a> ("+f[O]+")</div>";A=R[O+1]||"";m="";s=function(){if(M-1>0){m+="</div>";if(!A){M--;s()}else{for(K=M;K>=1;K--){if(J[K-1]!=A[K-1]){K=2;break}if(J[K-1]==A[K-1]&&K==1){break}}if(K==1){m=m.replace("</div>","")}else{M--;s()}}}};s();w+=m}};o()}}if(a==1){w+=I+"</div>";a=0}}l("treeLabel_main").innerHTML=w;t="<a href='javascript:treeLabel.toggle(1);'>"+v+"</a><span class='treeLabel_catText'><a href='javascript:treeLabel.toggle(1);'>"+treeLabel.openText+"</a></span> ";t+="<a href='javascript:treeLabel.toggle(0);'>"+e+"</a><span class='treeLabel_catText'><a href='javascript:treeLabel.toggle(0);'>"+treeLabel.closeText+"</a></span> ";if(navigator.userAgent.indexOf("MSIE")<0){t+=Q}l("treeLabel_toggle").innerHTML=t})(); //]]> </script>
〈2〉修改文章標籤設定 要使用這個樹狀標籤系統的話,必須將標籤名稱改為階層式,彼此之間用 "-" 分隔開。本版本支援多層次標籤,想分幾層就能分幾層,例如 "AAA-BBB-CCC-DDD-EEE" 就能分成五層囉!,再例如設定了 "健康-飲食-早餐" 這個標籤後,大分類是 "健康"、次分類是 "健康-飲食",真實標籤名稱是 "早餐"
〈3〉只印出真實標籤
<!-- 樹狀標籤只顯示真實標籤 start --> <a expr:href='data:label.url' rel='tag'> <script> (function() { var oldLabel = "<data:label.name/>".split("-"), l = oldLabel.length, newLabel = oldLabel[l - 1]; document.write(newLabel); })(); </script> </a> <!-- 樹狀標籤只顯示真實標籤 end, designed by WFU BLOG -->
樹狀分類程式設計
☞ WFU BLOG | 讓Blogger的標籤能「多層」樹狀分類__(一)基本安裝☞ WFU BLOG | [教學]Blogger文章分類﹍多層樹狀標籤(更新版)
☞ WFU BLOG | 讓 Blogger 樹狀標籤只顯示真實標籤名稱
沒有留言: