INDEX ≫ ブログのトップページに戻る


JUGEMのカテゴリーをツリー化してみました。

勿論私が考えた訳ではありません。
世の中には便利なものを「無償で」公開してくださる方がいるのです。
菩薩のようです。
 


これがツリー化です。
カテゴリが階層毎になるので、見やすいのです。
公開して下さったのstroll様に感謝です。

では早速手順です〜〜

JUGEMのサイトでカテゴリの編集画面を開き、
  カテゴリ名を"メインカテゴリー名(サブカテゴリー名)" にします。
  ※カッコは半角。
  サンプルので言うと、「INTERIOR(雑貨)」「INTERIOR(家電)」 ...と言った感じ。

▲屮蹈阿離妊競ぅ麒儿慌萍未如HTMLタグを開いて、
  </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>

以上で完了です!
とっても簡単でオススメです〜〜




 

Lightbox
(↑画面キャプチャです)

最近ネイルサロンとかのブログでもちょいちょい見ますが、
画像をクリックすると、別ウインドウ等ではなく
同一ウインドウにググっと画像が表示されるあれです。
(このサイトは似た動きですが、
LightBoxとは違うプラグインなので、それは別の記事でご紹介しますー)


導入にあたって外部サーバーが必要ですが、
JugemだとHPやってないよ!という方向けに対策が練られてました。
そういう心遣いってステキ///

やり方は「続きを読む」からどうぞー
続きを読む >>




S M T W T F S
 123456
78910111213
14151617181920
21222324252627
28293031   


author:ユキ






qrcode

みんなのブログポータル JUGEM

1