兔源码网 - 专注DZ模版分享、DZ插件分享!

 找回密码
 立即注册

QQ登录

只需一步,快速开始

广告
温馨提示:本站所有DZ相关模板、插件、教程(包括DZ应用中心已下架插件、模板)皆为提供免费下载,无任何收费模式(不包括VIP版块非DZ资源,VIP版块需充值兔币购买会员组方可下载),用户仅需手动前往【申请下载权限】申请用户组下载权限即可,如本站没有您需要的插件或模板,请自行前往淘宝互站网送吗网等第三方站点搜索相关插件或模板进行低价格购买下载本站非常不建议用户浪费金钱前往DZ应用中心购买。

在ECSHOP后台自定义价格区间,让价格区间更人性化

[复制链接]
tuzi 发表于 2015-8-9 00:11:32 | 显示全部楼层 |阅读模式
温馨提醒:禁止内容附带广告图片、二维码图片,否则将在不通知情况下永久禁言账号!
欢迎加入兔源码站长交流群,您的加入是我们前行的动力!

DZ站长建站交流群:493651246

[ 温馨提示:点击上方群文字,可快速加入QQ群 ]


众所周知,ECSHOP的价格区间是在后台设置一个“价格区间个数”,然后由程序来自动平分,很多ECSHOP网店主都认为这样做,有很大不尽人意的地方。, A- F7 M( L# X9 x, w
8 c6 I! h* S8 n' j$ _
论坛里也有人提供过修改方法,好像只是在模板文件里手动写死几个区间的一种方法,还是不能自由定义。
1 g1 M1 K3 W6 x* g7 x4 d! L0 V1 v4 u3 z' {8 S5 g
下面我要讲的方法是可以在ECSHOP后台自由定义价格区间(例如:1-30,31-200,201-1000,1001-5000,5000以上),前台自动体现的一种方法,而且每个类别的价格区间可以任意设置,让价格区间更人性化。# `. W- z. {' m0 x$ T
5 Q" N- e2 Q' a0 z
首先送上演示地址:演示地址已关,请询问客服" T% C2 L0 y; A! Y/ B

9 P! r6 m, m$ j" e3 v: }# w. C1)、
首先我们来修改ECSHOP的数据库结构,目的是给 ecs_category 增加一个新字段,
进入 后台 》 数据库管理  》SQL查询,执行下面的SQL语句
ALTER TABLE `ecs_category` ADD `grade_define` VARCHAR( 255 ) NOT NULL AFTER `grade`
注意:这里我使用的是 默认数据库前缀ecs_,如果你的数据库前缀不是 ecs_  , 请修改之。
/ o$ g! k5 E3 h: x
- ]- }( J/ {4 k8 G2)、- ^* C: ]$ [& S& g- l$ Q0 |$ G
! Q, b9 s, Q0 L; ~+ _! G
打开 /admin/templates/category_info.htm
找到
<tr>, b- e" ^: h# J- \6 [
        <td class="label"><a href="javascript:showNotice('noticeGrade');" title="{$lang.form_notice}"><img src="images/notice.gif" width="16" height="16" border="0" alt="{$lang.notice_style}"></a>{$lang.grade}:</td>
  n* G& Z2 O  ?        <td>( O7 C& h% t) \, t: [' x- f
          <input type="text" name="grade" value="{$cat_info.grade|default:0}" size="40" /> <br />4 W9 }# w( E4 [7 J% Z6 z' D
          <span class="notice-span" {if $help_open}style="display:block" {else} style="display:none" {/if} id="noticeGrade">{$lang.notice_grade}</span>
" p4 Z/ H5 Q) n% y        </td>+ Y% ?5 Y4 P8 u, c
      </tr>
0 F( w% T7 p0 `4 T/ X
将它修改为
<tr>
  P( F! Y2 H& e        <td class="label">自定义价格区间:</td>; u' a2 y2 d5 ]1 j: Z* f4 ]- ~
        <td>
# t/ t- S; @! G          <input type="text" name="grade_define" value="{$cat_info.grade_define}" size="60" /> <br />: O, \  z' U3 E* I1 L( F4 I8 {
          <span class="notice-span" {if $help_open}style="display:block" {else} style="display:none" {/if} id="noticeGrade">以 半角 , 间隔,如: 1-30,31-200,201-1000,1001-5000,5000以上</span>
1 S7 S5 w$ v7 L; v        </td>5 R- T" p8 h5 L- r% m
      </tr>

( v  `5 Y% |8 |5 d( I
* S8 o" c, e) s* Y- z
3)、5 P0 B  m/ s4 S# y7 \

  I  W6 C( z4 t+ Z+ F9 T# w4 t接着打开  /admin/category.php 文件,搜索

9 U: W3 o+ g; ~4 p
$cat['grade']        = !empty($_POST['grade'])        ? intval($_POST['grade'])      : 0;
5 m' `3 W5 x+ ^4 A: F6 @6 S
一共能搜到两处,在每一处的下面都增加代码(注意是每一处)0 p% T/ a4 B3 v

+ x' h1 D1 C! Z$ D# j6 o) s& J( V
$cat['grade_define']  = !empty($_POST['grade_define']) ? trim($_POST['grade_define'])  : '';  //自定义价格区间 by zhangyh
  V7 K, a9 z: k6 o
到此,后台管理部分修改完毕。 4 n( P: S/ z% Z! G8 ?. x# G& P" a

/ Y, T( _1 f* r% s4)、( {; m- h. e+ r" D; l, J# `

3 g- k2 z! z7 G" n, ?4 \( W下面开始修改前台部分
. Y1 Y9 Y, j( T
打开  /category.php
找到
/* 获取价格分级 */" j6 |2 e! W' h
    if ($cat['grade'] == 0  && $cat['parent_id'] != 0)( ?  N) W" f9 v4 E9 P6 l
    {
2 t6 @4 ?. }/ h/ @& L        $cat['grade'] = get_parent_grade($cat_id); //如果当前分类级别为空,取最近的上级分类
8 f4 h4 ?" o( M/ k. E    }
    if ($cat['grade'] > 1)
7 L5 m  m# t1 W, s6 t8 b8 Y+ L; ~    {
/ O1 S, ^+ R5 T2 ^        /* 需要价格分级 */
        /*
" z# R2 c  w6 W, E7 u9 c- ?1 S* d            算法思路:$ \/ w: x6 @1 L$ W/ H( w& w
                1、当分级大于1时,进行价格分级1 O  A2 O+ y0 f/ C" L$ J* U
                2、取出该类下商品价格的最大值、最小值2 \" D/ R4 L$ `- E: `6 D( {
                3、根据商品价格的最大值来计算商品价格的分级数量级:1 |* e9 \# z- |' I; H1 e. ~
                        价格范围(不含最大值)    分级数量级5 M9 i  v3 J- B( W( c; v& x
                        0-0.1                   0.0011 p) p. m: G4 R: @% T  T; v) S' l
                        0.1-1                   0.01
$ y5 i& v! \7 V" P$ `- ^                        1-10                    0.1
7 W3 n6 V; H" W; r) |                        10-100                  1( p# j/ h, _4 @7 y+ f
                        100-1000                10
! s+ y1 |% K) w* f' }                        1000-10000              100
- J+ c2 k0 i; \" n                4、计算价格跨度:
* W: }) t& Y) ^! \8 E5 d                        取整((最大值-最小值) / (价格分级数) / 数量级) * 数量级
) e6 V' }$ c% ^( C4 t                5、根据价格跨度计算价格范围区间8 o' j- M8 j0 Y, i
                6、查询数据库
            可能存在问题:
' A. o& _3 g9 w$ t% ]' |& N                1、
4 s" C: X7 m1 D1 y- I0 S) [6 a) _                由于价格跨度是由最大值、最小值计算出来的0 y0 K# S; x' C1 V0 h( d# |7 k1 a
                然后再通过价格跨度来确定显示时的价格范围区间, @8 |+ C1 \- H
                所以可能会存在价格分级数量不正确的问题
# ?' k' N. Q+ l4 j1 k1 O  o  y( }                该问题没有证明6 L6 q- @, }9 J% Q: E
                2、( K& L7 |$ J+ T3 a2 O7 X+ Z: K
                当价格=最大值时,分级会多出来,已被证明存在; \6 c& K$ r& |9 F' F7 S
        */
        $sql = "SELECT min(g.shop_price) AS min, max(g.shop_price) as max ".2 A; L0 v* r) T8 Y' L, g
               " FROM " . $ecs->table('goods'). " AS g ".9 t' j; K  Y) O  e
               " WHERE ($children OR " . get_extension_goods($children) . ') AND g.is_delete = 0 AND g.is_on_sale = 1 AND g.is_alone_sale = 1  ';% |6 x( J# z( U8 e! x5 K; _
               //获得当前分类下商品价格的最大值、最小值
        $row = $db->getRow($sql);
        // 取得价格分级最小单位级数,比如,千元商品最小以100为级数
: |$ P- j& n( C" w$ b. p        $price_grade = 0.0001;
, o, c6 S+ A* u5 ]& |        for($i=-2; $i<= log10($row['max']); $i++)
- W9 |; S& B, v        {
# n1 k. P! \) [% i/ d  G            $price_grade *= 10;+ p8 R* ]6 C* t5 g
        }
        //跨度
1 p( U3 v  L+ ^* }# [% o        $dx = ceil(($row['max'] - $row['min']) / ($cat['grade']) / $price_grade) * $price_grade;7 H- n  `) [7 d! @0 E- d8 v
        if($dx == 0)
' d4 i9 \* o- Z& x: @% ?7 Z        {6 |/ j$ y! `+ J# b2 Z1 R. t
            $dx = $price_grade;* b8 A9 p; S' y( T- I3 F
        }
        for($i = 1; $row['min'] > $dx * $i; $i ++);
        for($j = 1; $row['min'] > $dx * ($i-1) + $price_grade * $j; $j++);
, [* E: O/ ]. F+ _) n        $row['min'] = $dx * ($i-1) + $price_grade * ($j - 1);
        for(; $row['max'] >= $dx * $i; $i ++);+ X( N* H. q+ `
        $row['max'] = $dx * ($i) + $price_grade * ($j - 1);
        $sql = "SELECT (FLOOR((g.shop_price - $row[min]) / $dx)) AS sn, COUNT(*) AS goods_num  ".
% l, ]) ^) z# o- ]               " FROM " . $ecs->table('goods') . " AS g ".$ N1 y  n$ p, V' ^
               " WHERE ($children OR " . get_extension_goods($children) . ') AND g.is_delete = 0 AND g.is_on_sale = 1 AND g.is_alone_sale = 1 '.1 w" T  Z0 e3 l3 O* ]
               " GROUP BY sn ";
        $price_grade = $db->getAll($sql);
        foreach ($price_grade as $key=>$val)# u2 j, u2 a$ ]1 [/ S$ L& J
        {
/ E! z5 B" ~( j0 w4 n            $temp_key = $key + 1;
0 E9 E6 N7 N  {- o7 Z8 F' m            $price_grade[$temp_key]['goods_num'] = $val['goods_num'];
$ F" d+ z0 ], p: v, J            $price_grade[$temp_key]['start'] = $row['min'] + round($dx * $val['sn']);5 W: x" ?6 v; R
            $price_grade[$temp_key]['end'] = $row['min'] + round($dx * ($val['sn'] + 1));
& N# f. q# t3 Z6 ~            $price_grade[$temp_key]['price_range'] = $price_grade[$temp_key]['start'] . '&nbsp;-&nbsp;' . $price_grade[$temp_key]['end'];/ g4 q( Q& |4 C6 u9 P4 Q* U
            $price_grade[$temp_key]['formated_start'] = price_format($price_grade[$temp_key]['start']);
* @  B7 w# `( j) u; C6 Y            $price_grade[$temp_key]['formated_end'] = price_format($price_grade[$temp_key]['end']);. d) y  `+ z0 J$ g' y. n9 ?
            $price_grade[$temp_key]['url'] = build_uri('category', array('cid'=>$cat_id, 'bid'=>$brand, 'price_min'=>$price_grade[$temp_key]['start'], 'price_max'=> $price_grade[$temp_key]['end'], 'filter_attr'=>$filter_attr_str), $cat['cat_name']);
            /* 判断价格区间是否被选中 */9 ]. |" A' ]: T3 q% B7 e5 N
            if (isset($_REQUEST['price_min']) && $price_grade[$temp_key]['start'] == $price_min && $price_grade[$temp_key]['end'] == $price_max)
/ T& f2 w# A& A9 b9 J  G% i0 n            {
8 M/ F/ _& a- W8 `+ w                $price_grade[$temp_key]['selected'] = 1;
. l/ R3 W1 O; k( j  i  K- H            }
( C. m/ S- [9 d. K: l2 A9 L1 W8 ~            else
" L6 X+ e- y& ?) {. c+ G            {' o+ T8 p( z- }9 O
                $price_grade[$temp_key]['selected'] = 0;, y4 D8 V& ~$ z& @; B) h6 e" z0 I, o' x
            }4 S$ I' x: A: m4 p$ z
        }
        $price_grade[0]['start'] = 0;
/ I/ q: L" |, [2 `: H        $price_grade[0]['end'] = 0;: t9 o$ C* W; y3 d# N  @
        $price_grade[0]['price_range'] = $_LANG['all_attribute'];1 K; v2 e) v4 r
        $price_grade[0]['url'] = build_uri('category', array('cid'=>$cat_id, 'bid'=>$brand, 'price_min'=>0, 'price_max'=> 0, 'filter_attr'=>$filter_attr_str), $cat['cat_name']);8 |7 \+ a$ C8 g1 m& x. B+ O
        $price_grade[0]['selected'] = empty($price_max) ? 1 : 0;
        $smarty->assign('price_grade',     $price_grade);
    }
- c8 R' R; _6 A! Q
' W3 M& \5 d% g: ?
将它替换为
/* 获取价格分级_新 */. C$ y4 d' a0 p' X
if($cat['grade_define'])
& K3 t6 u0 k$ e/ _& l {/ h3 h* u; @+ l( x1 Q: G
$price_grade=array();
/ S8 M$ Z" [' T: Q! e2 K $price_grade[0]['start'] = 0;1 h' }6 b, u' d# L" u) L3 A6 A8 ^
    $price_grade[0]['end'] = 0;
7 s1 P" q3 F" J# A4 A' D9 `    $price_grade[0]['price_range'] = $_LANG['all_attribute'];* ^7 s2 A8 z. t# N) k' {
    $price_grade[0]['url'] = build_uri('category', array('cid'=>$cat_id, 'bid'=>$brand,
+ F- X6 }$ s  y% w( z. s  'price_min'=>0, 'price_max'=> 0, 'filter_attr'=>$filter_attr_str), $cat['cat_name']);  M" B9 [% a8 d) {
    $price_grade[0]['selected'] = empty($price_max) ? 1 : 0;
$grade_temp=explode(",", $cat['grade_define']);
) v# @1 W% q: D8 D" c, y foreach($grade_temp as $grade_temp_key=>$grade_temp_val)4 f( r0 N; Q6 A4 _6 b6 L( s
{
$ @* n, p# Y& z+ {, B, e  $grade_temp_key2=$grade_temp_key+1;0 E7 R( |* d& Z7 G1 a
  $grade_temp=explode("-", $grade_temp_val);- ]$ r6 ]' A! ~
  $price_grade[$grade_temp_key2]['start']=intval($grade_temp[0]);
8 I4 x6 K6 F7 H9 Q) c$ [+ @: A, D  $price_grade[$grade_temp_key2]['end']=$grade_temp[1] ?
. R/ L8 G+ D9 L" x* e   intval($grade_temp[1]) : "999999999";# W2 \* v8 y) `* d* ^4 {1 p
  $price_grade[$grade_temp_key2]['price_range'] = $grade_temp_val;
$ w% ]2 ?6 ~0 R- {8 S  n  $price_grade[$grade_temp_key2]['url'] = build_uri('category', array('cid'=>$cat_id,
" T8 B8 r, R+ W$ I: g+ ^   'bid'=>$brand, 'price_min'=>$price_grade[$grade_temp_key2]['start'],: Q. A7 O( u/ ^' {$ Z4 a! J
   'price_max'=> $price_grade[$grade_temp_key2]['end'],% u- p  ]) ?$ M) `+ [& B
   'filter_attr'=>$filter_attr_str), $cat['cat_name']);5 j4 `( l8 d7 R  L3 O6 s& ?5 S
        /* 判断价格区间是否被选中 */
+ ]: f4 ^) w* o2 [& E            if (isset($_REQUEST['price_min'])
; _' t! O9 y) T" J5 G2 C2 u    && $price_grade[$grade_temp_key2]['start'] == $price_min
, M* b3 d* a+ |9 `& V, W+ y, ?    && $price_grade[$grade_temp_key2]['end'] == $price_max)' M: V$ D# A( _8 w6 D
            {& \% p7 y) C; K
                $price_grade[$grade_temp_key2]['selected'] = 1;* i3 s$ p  q1 G) Z$ m
            }
1 S4 q" `/ y/ L+ g" f9 H6 N+ P# N            else7 U3 i  ^; b. m( B7 J' B
            {
' H2 f& j, s: c4 q3 j3 A                $price_grade[$grade_temp_key2]['selected'] = 0;
: M& a4 U1 a( ~2 p0 Y. @+ ~8 d$ G            }% P6 P) I9 ]5 ]# y5 d8 j; Y
}
/ _8 z% B1 l5 ^% K# q* }/ F $smarty->assign('price_grade',     $price_grade);
/ h0 K! F- A) C  f" p }

$ h- |0 y3 h- X- r7 y% w最后一步,找到+ Q. g  _2 I4 G' {) Y

9 {. F( ~$ f/ Y1 E) ^' E
return $GLOBALS['db']->getRow('SELECT cat_name, keywords, cat_desc, style, grade, filter_attr, parent_id FROM ' . $GLOBALS['ecs']->table('category') .
2 V8 k3 v3 w, y, C4 R( Z        " WHERE cat_id = '$cat_id'");

5 q2 t* y) P# Z9 f将之修改为
+ S6 E* G+ ^. }/ Z( G% ?
! l4 M  x9 P0 X. e7 c
return $GLOBALS['db']->getRow('SELECT cat_name, keywords, cat_desc, style, grade, grade_define, filter_attr, parent_id FROM ' . $GLOBALS['ecs']->table('category') .
6 d6 V( Y9 I* W3 T% i( b" N        " WHERE cat_id = '$cat_id'");
1 H( K3 K9 {) N; o  K$ P1 v/ w

版权声明
1、转摘或引用本站内容资源须注明原网址,并标明本站网址(兔源码www.tuyuanma.com);
2、对于转摘或引用本站内容资源而引起的民事纠纷、行政处罚或其他损失,本站不承担责任;
3、对于不遵守本声明或其他违法、恶意使用本站内容者,本站保留其追究法律责任的权利。




自动排版 | 高级模式
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

广告

兔源码网 ( 赣ICP备17001544号 公网安备36112102000036号 )

兔源码 QQ交流群:493651246  GMT+8, 2019-9-21 04:17
←站长统计工具 查看密码:tuyuanma

兔源码DZ模板下载 站长邮箱:tuyuanma@qq.com 站长QQ:3197813386 网站地图

© 2001-2013 本站内容皆来自互联网及用户分享,如需删除请提供软著或商标证书。

     
快速回复 返回顶部 返回列表