IMUZA.com

<<WordPress(ConoHa)<<はてなブログ

ホーム / Joomla! / Joomla!(11)テンプレートを自作する -Bootstrapテンプレートを移植する3-

Joomla!(11)テンプレートを自作する -Bootstrapテンプレートを移植する3-

2015/12/1 Joomla!

Bootstrapテンプレートを移植する2 に続いて index.php を作っていきます。前回も書きましたように説明のためにボトムアップ的に書いていますが、実際に作成する場合は、まず全体の構成を考え、モジュール名などを決定したうえで作業にかかるべきだと思います。

前回でヘッダー部分ができましたのでスライダーからです。

  • $this->countModules を使ってブロック表示を条件指定
  • templateDetailes.xml にモジュール表示位置を追加
  • モジュールの表示位置を指定
  • デモサイト

$this->countModules を使ってブロック表示を条件指定

モジュールを呼び出すには、前回使った

<jdoc:include type="modules" name="モジュール表示位置" />

ですが、その表示位置にモジュールがあるかどうか分かりませんので、次のメソッドを使って条件指定します。

<?php if($this->countModules('モジュール表示位置')): ?>
    // コード
<?php endif; ?>

たとえばスライダーの場合は次のようになります。

    <?php if($this->countModules('slider')): ?>
    <section id="main-slider" class="no-margin">
        <jdoc:include type="modules" name="slider" />
    </section><!--/#main-slider-->
    <?php endif; ?>

モジュール位置 slider には後ほど前々回オリジナルテンプレートから抜き出してモジュール > カスタムHTML として保存したスライダーを指定します。

他のブロックにもモジュール指定した index.php は次のようになります。

<body>
    <header class="navbar navbar-inverse navbar-fixed-top wet-asphalt" role="banner">
        <div class="container">
            <div class="navbar-header">
                <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
                    <span class="sr-only">Toggle navigation</span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                    <span class="icon-bar"></span>
                </button>
                <a class="navbar-brand" href="<?php echo JURI::root(); ?>"><?php echo $logo; ?></a>
            </div>
            <div class="collapse navbar-collapse">
                <jdoc:include type="modules" name="nav" />        
            </div>
        </div>
    </header><!--/header-->


    <?php if($this->countModules('slider')): ?>
    <section id="main-slider" class="no-margin">
        <jdoc:include type="modules" name="slider" />
    </section><!--/#main-slider-->
    <?php endif; ?>


    <?php if($this->countModules('feature')): ?>
    <section id="services" class="emerald">
        <div class="container">
            <div class="row">
                <jdoc:include type="modules" name="feature" />
            </div>
        </div>
    </section><!--/#services-->
    <?php endif; ?>


    <section id="recent-works">


    </section><!--/#recent-works-->


    <?php if($this->countModules('testimonial')): ?>
    <section id="testimonial" class="alizarin">
        <div class="container">
            <div class="row">
                <jdoc:include type="modules" name="testimonial" />
            </div>
        </div>
    </section><!--/#testimonial-->
    <?php endif; ?>


    <?php if($this->countModules('bottom')): ?>
    <section id="bottom" class="wet-asphalt">
        <div class="container">
            <div class="row">
                <jdoc:include type="modules" name="bottom" />
            </div>
        </div>
    </section><!--/#bottom-->
    <?php endif; ?>


    <footer id="footer" class="midnight-blue">
        <div class="container">
            <div class="row">
                <div class="col-sm-6">
                    <jdoc:include type="modules" name="footer" />
                </div>
                <div class="col-sm-6">
                    <ul class="pull-right">
                        <li><a id="gototop" class="gototop" href="#"><i class="icon-chevron-up"></i></a></li><!--#gototop-->
                    </ul>
                </div>
            </div>
        </div>
    </footer><!--/#footer-->


</body>

templateDetailes.xml にモジュール表示位置を追加

以下を templateDetailes.xml に追加します。

 <positions>
        <position>nav</position>
        <position>slider</position>
        <position>feature</position>
        <position>testimonial</position>
        <position>bottom</position>
        <position>footer</position>
    </positions>

モジュールの表示位置を指定

それぞれ保存してあるモジュールの表示位置を指定します。

slider, feature, testimonial を指定するモジュールは、メニューの割り当てタブでホームのみに割り当てます。

デモサイト

一度確認してみましょう。デモサイトを立ち上げましたのでそのリンクと画像です。スライダーの画像は Beautiful Free Images & Pictures | Unsplash の画像を使用しています。

デモサイト

ご覧のように feature, testimonial, bottom のグリッドが指定してありませんのでモジュールが縦に並んでいます。今回で完成予定でしたが長くなってきましたのでまた次回ということで。

Joomla!(10)テンプレートを自作する -Bootstrapテンプレートを移植する2-
Joomla!(12)テンプレートを自作する -Bootstrapテンプレートを移植する4-
Twitter
Facebook
ブックマーク
LINEで送る

最初のサイドバー

最新記事

2022/07/29

WordPressでiframeが表示されない(解決)

2022/07/14

WordPressのデータベースを入れ替える

2022/07/7

WordPress:テーマをゼロから作ってみる(3)

2022/06/26

WordPress:Aレコード変更でウェブだけ他サーバへ移転

2022/06/13

WordPress Popular Posts 他のプラグインに変えたほうがいいかも

最新記事を一覧で見る

よく読まれている記事

よく読まれている記事を一覧で見る

カテゴリー

  • はてなブログ212
  • WebTips108
  • javascript95
  • Joomla!88
  • Windows68
  • CSS62
  • Joomla!更新53
  • Linux49
  • はてなテーマ45
  • Wordpress37
  • Plamo33
  • Google32
  • はてなプラグイン25
  • php19
  • Node.js18
  • SASS16
  • Ubuntu16
  • laravel415
  • Chrome10
  • cms-style10
  • iPhone9
  • genesis6
  • Git入門6
  • ConoHa WING5
  • Python4
  • Android4
  • SSD3
  • Docker3
  • スマートフォン3
  • Facebook3
  • Firefox3
  • 静的サイトジェネレーター3
  • Blankslate3
  • Mactype2
  • GitHub2
  • rails入門1
  • はてなブクマ1
  • Twitter1
  • 映画1
  • youtube1

Footer

My Web Sites

  • @半径とことこ60分
  • そんなには褒めないよ。映画評
  • IMUZA.com
  • GitHub

Another Sites

  • WordPress公式
  • WordPress関数リファレンス
  • PHPマニュアル

Contact Us

  • お問い合わせフォーム
  • Twitter
  • Facebook
  • Feedly

Copyright © 2022 · IMUZA.com