PLP页面中的排序功能,如按照销量排序,按照人气排序等

1.在后台中新建产品属性salestotal用作销量排序
2.新建Tang/ProductSales模块
3.配置模块的config.xml文件

<?xml version="1.0"?>
<config>

    <modules>
        <Tang_ProductSales>
            <version>0.1.0</version>
       </Tang_ProductSales>
    </modules>

    <frontend>

        <routers>
            <productsales>
                <use>standard</use>
                <args>
                    <module>Tang_ProductSales</module>
                    <frontName>productsales</frontName>
                </args>
            </productsales>
        </routers>

        <layout>
            <updates>
                <productsales>
                    <file>productsales.xml</file>
                </productsales>
            </updates>
        </layout>

    </frontend>

    <global>

        <models>
            <productsales>
                <class>Tang_ProductSales_Model</class>
                <resourceModel>productsales_resource</resourceModel>
            </productsales>
            <!-- st 数据库资源模型配置 -->
            <productsales_resource>
                <class>Tang_ProductSales_Model_Resource</class>
                <deprecatedNode>productsales_mysql4</deprecatedNode>
                <entities>
                    <catalog_product_entity_varchar>
                        <table>catalog_product_entity_varchar</table>
                    </catalog_product_entity_varchar>
                </entities>
            </productsales_resource>
            <!-- end 数据库资源模型配置 -->
        </models>

        <events>
            <checkout_onepage_controller_success_action>
                <observers>
                    <productsales>
                        <!--
                        此处可以model、object、singleton
                        1. model和object是等效的且它们都将使用Mage::getModel(...)方法来进行初始化
                        2. 而singleton将使用Mage::getSingleton(...)来初始化
                        -->
                        <type>model</type>
                        <class>productsales/observer</class>
                        <method>preOrderSubmitInsertProductSales</method>
                    </productsales>
                </observers>
            </checkout_onepage_controller_success_action>
        </events>

        <helpers>
            <productsales>
                <class>Tang_ProductSales_Helper</class>
            </productsales>
        </helpers>

        <blocks>
            <productsales>
                <class>Tang_ProductSales_Block</class>
            </productsales>
        </blocks>

        <resources>
            <productsales_write>
                <connection>
                    <use>core_write</use>
                </connection>
            </productsales_write>
            <productsales_read>
                <connection>
                    <use>core_read</use>
                </connection>
            </productsales_read>
        </resources>

    </global>
</config>

4.配置监听时间,当提交订单后,订单中的产品销量属性加一

<?php
class Tang_ProductSales_Model_Observer extends  Mage_Catalog_Model_Observer
{
    public function preOrderSubmitInsertProductSales(Varien_Event_Observer $observer){
        $order = new Mage_Sales_Model_Order();
        $incrementId = Mage::getSingleton('checkout/session')->getLastRealOrderId(); //订单ID
        $order = Mage::getModel('sales/order')->loadByIncrementId($incrementId); //订单信息
        $orderItems = $order->getItemsCollection();

        foreach ($orderItems as $item) {
            //获取指定产品对象
            $prcProject = Mage::getModel('catalog/product')->load($item->getProductId());
            $attrProject = Mage::getModel('eav/entity_attribute')->load('renqi','attribute_code'); //获取指定属性标识码的属性信息
            $entypeid = $attrProject->getEntity_type_id(); //Eav类型
            $attrid = $attrProject->getAttribute_id(); //属性ID
            $storeid = 0; //商店ID
            $entityid = $item->getProductId(); //产品ID
            $_product = Mage::getResourceModel('reports/product_collection')
                ->addOrderedQty()
                ->addAttributeToFilter('sku', $prcProject->getSku())
                ->setOrder('ordered_qty', 'desc')
                ->getFirstItem();
            $svalue = (int)$_product->getOrderedQty();
//            $svalue = (int)$_product->addOrderedQty() + $prcProject->getSalestotal(); //销量累加
            if($svalue >0){
                $ifused = true;
            }else{
                $ifused = false;
            }
            Mage::getResourceSingleton('productsales/salestotal')->updProductSalesTotal($entypeid, $attrid, $storeid, $entityid, $svalue, $ifused);

        }
        return $this;
    }
}

4.对销量属性进行写入:

<?php
class Tang_ProductSales_Model_Resource_Salestotal extends Mage_Core_Model_Resource_Db_Abstract
{
    protected function _construct() {
        $this->_init("productsales/catalog_product_entity_varchar","value_id");
    }

    /**
     * 添加产品销量到产品信息中
     * @param int $entypeid eav类型
     * @param int $attrid 属性ID
     * @param int $storeid 商店ID
     * @param int $entityid 产品ID
     * @param varchar $svalue 销量
     * @param bool $ifused 是否已存在
     * @return number
     */

    public function updProductSalesTotal($entypeid, $attrid, $storeid, $entityid, $svalue, $ifused){
        $selfread = $this->_getConnection('productsales_write');
        $table = $this->getTable('productsales/catalog_product_entity_varchar');
        //存入数组的数据
        $sdata = array("entity_type_id"=>$entypeid, 'attribute_id'=>$attrid, 'store_id'=>$storeid, 'entity_id'=>$entityid, 'value'=>$svalue);
        //查询条件
        if($ifused){
            $swhere = " attribute_id=$attrid"." AND entity_id=$entityid";
            //执行更新操作
            return $selfread->update($table, $sdata, $swhere);
        }else{
            //执行插入操作
            return $selfread->insert($table, $sdata);
        }
    }
}

具体可以参考旺铺商城的项目

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,594评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,424评论 25 707
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,732评论 6 342
  • 我是一名大学生,可是我并没有觉得我的前途无量,反而我根本就不知道我以后能做什么。我们大学生大多数都只是相对于那些非...
    字墨书香阅读 554评论 0 4
  • 故事情节顺理成章的进行着,不过还算有个小意外的结局,钱老写书就是写书,从不刻意用文字去讨好读者,只是没想到最吸引我...
    塞北的南阅读 257评论 0 1