ABOUT ME

                 

LATEST ENTRIES

CATEGORIES

RECENT COMMENTS

LINKS

【備忘録】カテゴリーのツリー化をおこなった。

いよいよ念願だった「カテゴリーのツリー化」をおこなった。

最初、ツリー化した上で折りたたみもできるようにしようとか欲を出したせいで、ちょっとおかしなことになってしまって随分苦戦したが、ツリー化だけに絞ってみたら、別になんてことはなかった。少々長いスクリプトをコピペするだけだった。

まあ、この処理自体は実は10年位前にFC2ブログで経験していたのだけど、当然のことながらすっかり忘れている上に、FC2は途中から、機能としてカテゴリのツリー化を用意したので、なんの苦労もなかった。

ということで、備忘録も兼ねて、続きを読む以下にスクリプトをコピペしておきたいと思います。

参照にさせていただいたブログは「POLICY.JUGEM.CC」さまです。URLが「jugem.cc」なので、ベータ版の時(13年くらい前?)からのユーザーさんのようですね。ということで、手順は以下のとおりです。

※参照元記事:カテゴリーリストをツリー化するスクリプト:JUGEM
 

■スクリプトをコピペする前の下準備

1:まずは予め「カテゴリ名」をいじっておく必要があります。
  ⇒具体的には、カテゴリー名を「メインカテゴリー名(サブカテゴリー名)」
   
という表示に変更します。 
   ※ カッコは半角で入力します。 




上記のようにすると、ブログ上では以下のように表示されます。




※親カテゴリには、当然のことながらリンクは生成されません。


2:HTML/CSS編集にて「{category_list} 」を探し、以下のように編集します。

<div id="categorylist">{category_list}</div>


UTF(ユーザー作成テンプレート)によっては、{category_list} がなく「プルダウンボックス」などに格納されている場合もあります。(このテンプレートが正にそうだった)

例えばこのブログのテンプレートの場合だと「{category_list}」ではなく「{category_box}」みたいな表示だったので、それらしきものを探して、上記のタグにそのまま上書きして書き換えればOKです!


3:</body> の直前に以下のスクリプトを貼り付ける。※めっちゃ長い
 

<script type="text/javascript" language="javascript">
<!--
//カテゴリーリストでサブカテゴリーがあるっぽく表示する
//ツリー化スクリプト ver 2 edit by stroll
function makeTreeElements (idName,objList) {
  if (!objList.innerHTML) return;
  var objLink = objList.getElementsByTagName('a')[0];
  var linkUrl = objLink.getAttribute('href');
  if (idName.indexOf('comment') > -1 || idName.indexOf('tb') > -1) {
    var tmpText = objList.innerHTML.split("⇒");
    tmpText[0] = tmpText[0].slice(0,tmpText[0].search(/<BR/i));
    this.base = Array('<a href="',linkUrl,'">',tmpText[0],'</a>').join('');
    this.elem = objLink.innerHTML;
  } else if (idName.indexOf('entry') > -1) {
    var tmpText = objList.innerHTML;
    tmpText.match(/¥((¥d¥d¥/¥d¥d)¥)/);
    this.base = Array('<strong>[',RegExp.$1,']</strong>').join('');
    this.elem = Array('<a href="',linkUrl,'">',objLink.innerHTML,'</a>').join('');
  } else if (idName.indexOf('link') > -1) {
    var tmpText = objList.innerHTML;
    if ( tmpText.match(/¥[(.+)¥](.+)/) ) {
      this.base = Array('<strong>[',RegExp.$1,']</strong>').join('');
      this.elem = Array('<a href="',linkUrl,'" target="_blank">',RegExp.$2,'</a>').join('');
    }
  } else if (idName.indexOf('category') > -1) {
    var tmpText = objList.innerHTML;
    if ( tmpText.match(/>(.+)¥((.+)¥).+(¥s¥(.+¥))/) ) {
      this.base = Array(RegExp.$1).join('');
      this.elem = Array('<a href="',linkUrl,'"> ',RegExp.$2, '</a>', RegExp.$3).join('');
    } else {
      this.base = Array('<a href="',linkUrl,'">',tmpText,'</a>').join('');
      this.elem = 'null';
    }
  }
  return this;
}
function createTreeList(idName,option) {
  var objFocus = this.document.getElementById(idName);
  if (!objFocus) return;
  if (!objFocus.innerHTML) return;
  var objLists = objFocus.getElementsByTagName('li');
  var linkList = new Array();
  var outText = new Array();
  var linkListNum = new Array();
  var count = 0;
  var tempDispNum = '';
  if (objLists.length > 0) {
    for (i=0;i<objLists.length;i++) {
      var chckFlag = true;
      var elemText = new makeTreeElements(idName,objLists[i]);
      if (!elemText.base || !elemText.elem) return;
      for (j=0;j<linkList.length;j++) {
        if (linkList[j].base.indexOf(elemText.base) > -1) {
          chckFlag = false;
          linkList[j][linkList[j].length] = elemText.elem;
        }
      }
      if (chckFlag) {
        var tmpNum = linkList.length;
        linkList[tmpNum] = new Array();
        linkList[tmpNum][0] = elemText.elem;
        linkList[tmpNum].base = elemText.base;
      }
    }

    if (idName == 'categorylist' && linkList.length > 0) {
      for (i=0;i<linkList.length;i++) {
        linkListNum[i] = 0;
        for (j=0;j<linkList[i].length;j++) {
          if (linkList[i][j] != 'null' && linkList[i][j].match(/¥s¥((.+)¥)/)) {
            linkListNum[i] = linkListNum[i] + parseInt(RegExp.$1);
          }
        }
      }
    }

    if (linkList.length > 0) {
      outText[outText.length] = '<ul>¥n';
      for (i=0;i<linkList.length;i++) {
        tempDispNum = '';
        if (idName == 'categorylist' && linkListNum[i] > 0) {
          tempDispNum = ' ('+linkListNum[i]+')';
        }
        outText[outText.length] = Array('<li>',linkList[i].base,tempDispNum,option.top).join('');
        if (linkList[i].length > 0 && option.sort) linkList[i].reverse();
        for (j=0;j<linkList[i].length;j++) {
          if (linkList[i][j] != 'null') {
            outText[outText.length] = (j == linkList[i].length - 1) ? option.end : option.list;
            outText[outText.length] = Array(linkList[i][j],option.leef).join('');
          }
        }
        outText[outText.length] = Array(option.btm,'</li>').join('');
      }
      outText[outText.length] = '</ul>¥n';
      objFocus.innerHTML = outText.join('');
    }
  }
}
var gTreeOption = new Array;
gTreeOption['sort'] = false;      /* ツリー内の表示順 true:並び替える false:そのまま */
gTreeOption['list'] = '  ├ ';      /* ツリー用マーク(通常) */
gTreeOption['end']  = '└ ';      /* ツリー用マーク(末端) */
gTreeOption['leef'] = '<br />¥n'; /* 各枝の末尾 */
gTreeOption['top']  = '<br />¥n'; /* ツリー本体の最初 */
gTreeOption['btm']  = '';         /* ツリー本体の最後 */
gTreeOption['num']  = 0;          /* ()の中身の数の合計数(値を変更しないでください) */

createTreeList('newentrylist',gTreeOption); // 最新エントリリストのツリー化
createTreeList('entrylist',gTreeOption);    // エントリリストのツリー化
createTreeList('commentlist',gTreeOption);  // 最新コメントリストのツリー化
createTreeList('tblist',gTreeOption);       // 最新トラックバックリストのツリー化
createTreeList('linklist',gTreeOption);     // リンクリストのツリー化
createTreeList('categorylist',gTreeOption); // カテゴリリストのツリー化
// -->
</script>


以上!

■初心者向けのアドバイス■
テンプレートを編集する時のコツとして「今使っているテンプレートを複製(コピー)」を作成してバックアップを取り、ダミーの方で一旦試して問題ないことを確認してから、改めてオリジナルの方での編集を行いましょう。
※テンプレートの編集でミスると、元に戻すのも一苦労なので、必ずそうした方がいいですよ。
 

こんなに文字装飾を多用した記事を書くの久しぶりやw


 
 

スポンサードリンク

コメント
コメントする








   
この記事のトラックバックURL
トラックバック