Magento——利用购物车促销规则(Shopping Cart Price Rules)实现自己的功能第一章: 添加新的动作(Actions)

简介:

Magento的促销规则引擎,可以用一个词,叫很好很强大,不过虽然可以在Magento后台可以设置很复杂的各种条件(Conditions),但条件对应的动作(Actions)却很少,而且全部都是只针对价格做文章。如下图:


其实利用这个引擎可以开发自己的各种需求功能,一些收费的插件就是这么在做的,包括几个积分插件,都是用这个引擎来设置积分获取和使用的规则。今天讲下我在利用促销引擎上的一些体会,第一篇讲的是如何添加新的动作(Actions),这个是针对Shopping Cart Price Rules的。

在模块的config.xml添加事件监听,监听adminhtml_block_salesrule_actions_prepareform事件:

           <events>
          <!--按促销规则送优惠券 -->
            <adminhtml_block_salesrule_actions_prepareform>
                <observers>
                    <coupon_present_action>
            						<type>model</type>
            						<class>Shuishui_Coupon_Helper_Data</class>
            						<method>presentCoupon</method>
                    </coupon_present_action>
                </observers>
            </adminhtml_block_salesrule_actions_prepareform>

          </events>

在对应的Data.php文件里编写监听该事件的函数presentCoupon

    //按促销规则送优惠券
    public function  presentCoupon($observer){

       $form = $observer->getForm();
       $fieldset=$form->getElement('action_fieldset');
       $options = '';
       foreach ($fieldset->getElements() as $element) {
             if($element->getName() == 'simple_action'){
                $options = $element->getOptions();
             } 
            }
            //送优惠券
            $options['present_coupon'] = '送X张Y类型优惠券(优惠金额为Y)'; 
            
            $fieldset->removeField('simple_action');
            $fieldset->addField('simple_action', 'select', array(
            'label'     => Mage::helper('salesrule')->__('Apply'),
            'name'      => 'simple_action',
            'options'    => $options,
                ),'^'); 
   
    
    }

效果如下:


现在,你就可以像设置自带的促销规则那样,设置自己想要在符合某种条件时所想要的操作,我这里以符合

某种条件时送优惠券为例(该优惠券功能是另外开发的,不在本文的讨论范围大笑)。

比如,购物满500送一张优惠券等等。条件设置为

操作选择自己刚刚添加的那个,其他设置与一般的规则设置一致。

这样,第一步添加新的动作(Actions)就完成了,至于如何在购物车页面验证这条自己新增的规则,下一篇文章再讲

PS:以上的代码只是例子,每个人可以在规则引擎的基础上按需求开发出自己需求的功能。

目录
相关文章
|
JavaScript 前端开发
56dwr - 购物车案例(调用远程的 Cart 方法)
56dwr - 购物车案例(调用远程的 Cart 方法)
42 0
|
存储 前端开发 JavaScript
53dwr - 购物车案例(实现目录)
53dwr - 购物车案例(实现目录)
54 0
|
8天前
|
JSON 安全 API
微店item_search_shop-获得店铺的所有商品API接口设计指南
本文介绍如何设计高效、安全且易用的item_search_shop API接口,用于微店商品检索和管理。关键需求包括数据完整性、高并发支持、安全性及易用性。开发者需在微店开放平台注册获取API凭证,并通过Access Token调用接口。接口支持一次性获取店铺所有商品信息,提供Python示例代码。注意事项涵盖凭证安全、异常处理和数据准确性。此API助力商家提升电商运营效率。
|
22天前
|
数据采集 JSON API
如何利用Python爬虫淘宝商品详情高级版(item_get_pro)API接口及返回值解析说明
本文介绍了如何利用Python爬虫技术调用淘宝商品详情高级版API接口(item_get_pro),获取商品的详细信息,包括标题、价格、销量等。文章涵盖了环境准备、API权限申请、请求构建和返回值解析等内容,强调了数据获取的合规性和安全性。
|
5月前
|
SQL 算法 Serverless
B端算法实践问题之使用concat_id算子获取用户最近点击的50个商品ID如何解决
B端算法实践问题之使用concat_id算子获取用户最近点击的50个商品ID如何解决
39 1
|
5月前
|
前端开发 数据库
SpringBoot+Vue实现商品不能重复加入购物车、购物车中展示商品的信息、删除商品重点提示等操作。如何点击图片实现图片放大
这篇文章介绍了如何在SpringBoot+Vue框架下实现购物车功能,包括防止商品重复加入、展示商品信息、删除商品时的提示,以及点击图片放大的前端实现。
SpringBoot+Vue实现商品不能重复加入购物车、购物车中展示商品的信息、删除商品重点提示等操作。如何点击图片实现图片放大
|
8月前
|
JavaScript 前端开发 定位技术
《vue3实战》在created生命周期中运用slice()方法结合element plus组件实现电影评价系统的分页
《vue3实战》在created生命周期中运用slice()方法结合element plus组件实现电影评价系统的分页
|
8月前
|
搜索推荐 API 开发工具
1688 商品评论数据接口(1688.item_review)
1688 商品评论数据接口(1688.item_review)
|
供应链 API 开发工具
1688店铺所有商品数据接口(1688.item_search_shop)
1688店铺所有商品数据接口(1688.item_search_shop)
|
JavaScript 前端开发 API
Angular1.4.6框架简单读取数据库信息并渲染完成news新闻文章列表以及detail详情页功能(小试牛刀)
Angular1.4.6框架简单读取数据库信息并渲染完成news新闻文章列表以及detail详情页功能(小试牛刀)

热门文章

最新文章

下一篇
开通oss服务