Home > Custom > ColorMe!ShopPro if文とか

ColorMe!ShopPro if文とか



ColorMe!ShopProのテンプレート構築で欠かせないif文とかについての解説。

if文というのは英語の意味と同じで「もし~ならば」という動作をする。
処理に説明をつけると次のようになります。

SMARTY:
  1. <{if (条件)}>//もし(条件)ならば~
  2. (条件に該当する場合の処理)を実行
  3. <{else}>//あてはまらなければ~
  4. (条件に該当しない場合の処理)を実行
  5. <{/if}>


ifの間にはelseifを加えて複数条件を分岐させることが出来ます。

SMARTY:
  1. <{if (条件)}>//もし(条件)ならば~
  2. (条件に該当する場合の処理)を実行
  3. <{elseif (条件2)}>//もし(条件2)ならば~
  4. (条件2に該当する場合の処理)を実行
  5. <{else}>//あてはまらなければ~
  6. (いずれにも該当しない場合の処理)を実行
  7. <{/if}>

上から条件と照らし合わせて比較していき、該当したら処理を実行してifから抜けます。
elseは省略してもエラーになりません。

ifの中にifを入れる事も出来ます。
入れ子に出来る数の上限はないものの、あんまり複雑にすると重くなるしエラーも出やすくなるのでほどほどに。

演算子について

ifに使う条件は演算子で書きますが、PHPで使用できるものはそのまま使えます。
右側が比較する側、左側が比較される側です。
文字の場合はダブルクォートで囲み、数値の場合はそのまま記述する。

A == B(等しい)
AとBが完全一致するかどうか比較します。代替はeq。

例:もしフリーページエリアの使用フラグがtrueならば(1ページでもフリーページがあればtrue)

SMARTY:
  1. <{if $free_area_flg == true}>

A != B(等しくない)
AとBが一致しないかどうか比較します。代替はneまたはneq。

例:もしおすすめ商品個数が0でないなら

SMARTY:
  1. <{if $recommend_num != 0}>

A > B(より大きい)
A >= B(より大きいか等しい)
AがBより大きいかどうか比較します。イコールをつけると等しい場合も該当する。
代替はgt。イコールが付く場合はgeまたはgte。

例:もしカテゴリIDが3より大きければ(セクション内で使用)

SMARTY:
  1. <{if $category[num].id> 3}>

A < B(より小さい)
A <= B(より小さいか等しい)
AがBより小さいかどうか比較します。イコールをつけると等しい場合も該当する。
代替はlt。イコールが付く場合はleまたはlte。

例:もしサブカテゴリー数が3より小さければ

SMARTY:
  1. <{if $subcategory_num <3}>

! A(否定)
Aじゃなければ、という意味です。
! A == Bというように式と組み合わせることも出来ます。
代替はnot。

A % B(余剰)
AをBで割って比較します。代替はmod。

例:もしトラックバック数が2で割って余りが0なら

SMARTY:
  1. <{ if $trackback_num % 2 ==0 }>

条件はいくつか繋げることが出来、論理演算子と呼ばれます。
主に次のようなものがあります。

A and B
A && B(かつ)
AとB(の式)を比較してどちらも該当する場合にtrue。

A or B
A || B(または)
AとB(の式)を比較してどちらかに該当すればtrue。

A xor B
どちらかには該当するけど両方には該当しない場合にtrue。

余剰の式は、3列ごとに改行入れるようなカラム操作で使われます。
テンプレート「ビューティ」のサブカテゴリ表示ソースを参考にすると

SMARTY:
  1. <!-- サブカテゴリー -->
  2. <!-- 該当するサブカテゴリーがないときは、表示しない -->
  3. <{if $subcategory_num != 0}>
  4.  
  5. <table width="100%" cellspacing="0" cellpadding="0">
  6.     <tr valign="bottom"><td class="round_top"><img src="http://img.shop-pro.jp/tmpl_img/15/title_subcat.gif" width="131" alt="サブカテゴリー" /></td></tr>
  7.     <tr>
  8.         <td class="round_bg">
  9.             <{section name=num loop=$sub_category}>
  10.             <div class="item_box">
  11.                 <a href="<{$sub_category[num].link_url}>"><{if $sub_category[num].img_url != "" }><img src="<{$sub_category[num].img_url}>" /><{/if}><{$sub_category[num].name}></a>
  12.             </div>
  13.             <!-- 4個で改行(最後は含まない) -->
  14.             <{if item">$smarty.section.num.iteration % 4 == 0 and item">$smarty.section.num.last == false}><br class="clear" /><{/if}>
  15.             <{/section}>
  16.         </td>
  17.     </tr>
  18.     <tr><td class="round_bottom"></td></tr>
  19. </table>
  20. <br />
  21. <{/if}>
  22. <!--// サブカテゴリー -->

セクションの中に入ってるifで条件に該当すれば改行する処理をしています。
▼この部分

SMARTY:
  1. <{if item">$smarty.section.num.iteration % 4 == 0 and item">$smarty.section.num.last == false}>

$smartyという予約変数は、環境変数やリクエスト変数に直接アクセスできるようになるものです。
$smarty.section.num.iterationという書き方では、numという名前のセクションループの反復された回数が入った変数、という感じ。

若干ややこしいですが次のような意味です。

$smarty.section.num.iteration % 4 == 0
numという名前のセクションループの反復された回数が、4で割って余らない場合
and
かつ
$smarty.section.num.last == false
最後の処理でなければ

この場合、4で割って余りが出なければという指示なので、横に4つ並べる処理になります。
3列や2列にしたい場合は$smarty.section.num.iteration % 4 を3や2など、並べたい数に変更する。

このエントリをはてなブックマークに追加このエントリをdel.icio.usに追加このエントリをLivedoor Clipに追加このエントリをYahoo!ブックマークに追加このエントリをFC2ブックマークに追加このエントリをNifty Clipに追加このエントリをPOOKMARK. Airlinesに追加このエントリをBuzzurl(バザール)に追加このエントリをChoixに追加このエントリをnewsingに追加

Comments:0

Comment Form
Remember personal info

Trackbacks:0

Trackback URL for this entry
http://tenderfeel.xsrv.jp/custom/98/trackback/
Listed below are links to weblogs that reference
ColorMe!ShopPro if文とか from WebTecNote

Home > Custom > ColorMe!ShopPro if文とか

最近の投稿
最近の修正
  • そしてこのSQLはわれながらよく書いたと思う 2010-11-15
  • CSVの列っていう方がいいのかな…118項目だった 2010-11-15
  • 楽天のCSVの項目が116個もあった衝撃 2010-11-15
  • オフィスで香水臭振りまくのは迷惑だと知れ 2010-11-15
  • ぐあー フレグランステロやー 2010-11-15
  • More updates...

Powered by Twitter Tools

Tag Cloud
おすすめサーバー・他
メタ情報

Return to page top