EC-CUBE

EC-Cubeカスタマイズ:商品一覧で表示順序の切り替えを追加

投稿日:2012年3月17日 更新日:

今日は備忘録です。
EC-Cubeの商品一覧画面って
初期では「価格順」「新着順」の2つだけしか無いのですが
もう少し追加したい・・・

ということで
「価格順」を価格が高い順と価格が安い順の2つに分けることにします。

修正するファイルは
テンプレートファイルと
クラスファイルの2つ

どのように動作しているかというと
リンクをクリックすると、Javascriptでテンプレート内の隠し項目「orderby」に
引数を入れてPOSTしています。
受け取った「orderby」の値を元に、商品検索の内部処理時のSQLに
order by句を当てはめているわけです。

ということで変更する方法は以下のとおりです。

まずはテンプレートファイルを変更
ファイル名:list.tpl
<a href=”javascript:fnModeSubmit(”, ‘orderby’, ‘price’)”>価格が安い順</a>

<a href=”javascript:fnModeSubmit(”, ‘orderby’, ‘price2’)”>価格が安い順</a>
を表示したい部分に修正・追加します。
基本的にはこれだけでOK

現在の表示順を表示したい場合は
<!–{if $orderby != ‘price’}–>
<!–{else}–>
&lt;!–{/if}-&gt;
の部分を編集します。

次にクラスファイルを変更
ファイル名:LC_Page_Products_List_Ex.php
継承元であるLC_Page_Products_List.phpから
以下の関数をコピーします。

lfDispProductsList

コピーした関数の
//表示順序
switch($orderby) {
}
の部分に追加した「price2」のorder by句を追記します。

case ‘price_2’:
$order = “price02_min desc, product_id”;
break;

簡単ですね!!

ad

ad

-EC-CUBE
-,

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

スパム対策 * Time limit is exhausted. Please reload the CAPTCHA.

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

関連記事

簡単・EC-CUBEカスタマイズ:新しいページを/user_data/以外に追加する

連載は相変わらずの持ち越しです・・・ <span style=”color:#f44;”>※この方法で追加したページに関してはPCでのみ動作確認をしております。 携 …

EC-Cubeカスタマイズ:マイページから会員情報変更をした際のsub_tilte

備忘録です。 バグというほどのものではないと思いますが テストをしていて違和感があったので修正方法を覚書・・・ ※この情報はVersion2.11.5の情報です 会員のマイページから登録済みの会員情報 …

EC-CUBEカスタマイズ:カテゴリーブロックで下層のカテゴリも表示する

本日連投です。 デフォルトで用意されているカテゴリ表示のブロックですが 第一回層のカテゴリしか表示されません。 これをすべての階層表示するように変更します。 修正する場所は、カテゴリ表示のテンプレート …

EC-Cube改造:商品詳細ページにサブの写真を表示する

またまた、備忘録です EC-Cubeの商品詳細ページには、メインのコメントや写真のほかにも サブの情報として、最大5個情報を表示することが可能です。 使い方によっては、写真のみをメインの写真+方向を変 …

EC-Cubeカスタマイズ:新たなブロックを追加する:新着商品表示ブロック

今日も備忘録です。 EC-CUBE 2.11.5のカスタマイズを開始しました。 例によって、EC-CUBE標準では新着商品の一覧を表示するブロックが無いので作ります。 手順 1.管理画面「デザイン管理 …