私がこれを実現するために調査/試行に費やした時間がどれほど信じられないでしょう。私が欲しいのは、注文に追加するクロスセル製品を顧客に尋ねた後、注文プロセスで追加のページを表示することだけです(私はそれらをアップセルと呼びますが、Magentoだと思います)用語は「クロスセル」です)。多くの企業がこれを望まないのは本当に信じられないことです(「アップセル」により利益が大幅に増加し、Magentoに組み込まれているものがあまりうまく機能しないと思います(「クロスセル」製品が20個以上あり、適合/表示しないでください)。
Magento ver。を使っています。1.9.1.0。
ポルトテーマ#11をインストールしました。
新しい情報:これを実装しようとしましたが、今のところ運がありません。私は誰かが私を手伝っていますが、それを理解することはできません。誰かがこれを行う方法を段階的に説明してくれますか?(どんな解決策も大歓迎です)。
proflowers.comと同じように機能させたい(同封のスクリーンショットを参照)。
お客様がカートに商品を追加した後の次のステップとして、このページが表示されます(チェックアウトに進むをクリックします)
すべてのクロスセル製品は常に すべての人に同じです(注文したすべての製品)
2016年11月15日に編集:
100の評判を獲得したソリューションは実際に機能します。私がやろうとしていることをやろうとしている人は、ファイルをダウンロードしてルートディレクトリにアップロードし、次のコードをapp/code/community/TM/SuggestPage/controllers/IndexController.php
ファイルに追加する必要があります。
$block2 = $this->getLayout()->createBlock('checkout/cart_coupon')->setTemplate('checkout/cart/coupon.phtml');
$this->getLayout()->getBlock('content')->append($block2);
まだ4つではなく、12の製品を特別なクロスセルページに表示する方法を理解しようとして います。
app/design/frontend/YourPackge/YourTheme/checkout/cart/
ここでcrossell.phtmlを見つけまし た:
/public_html/app/design/frontend/smartwave/porto/template/checkout/cart
(私はそれが正しいものであることを願っています-私はポルトテーマをインストールしています)
これは次のようになります。
<?php
/**
* Cart cross sell items template
*
* @see Mage_Checkout_Block_Cart_Crosssell
*/
$store = Mage::app()->getStore();
$code = $store->getCode();
$aspect_ratio = Mage::getStoreConfig("porto_settings/category/aspect_ratio",$code);
$ratio = ($aspect_ratio || (!$aspect_ratio && Mage::getStoreConfig("porto_settings/category/ratio_width",$code) == 0))?1:(Mage::getStoreConfig("porto_settings/category/ratio_height",$code)/Mage::getStoreConfig("porto_settings/category/ratio_width",$code));
?>
<?php if($this->getItemCount()): ?>
<div class="crosssell">
<h2><?php echo $this->__('Based on your selection, you may be interested in the following items:') ?></h2>
<ul id="crosssell-products-list" class="row">
<?php foreach ($this->getItems() as $_item): ?>
<li class="item col-sm-6 col-md-3">
<a class="product-image" href="<?php echo $_item->getProductUrl() ?>" title="<?php echo $this->escapeHtml($_item->getName()) ?>"><img src="<?php echo $this->helper('catalog/image')->init($_item, 'thumbnail')->resize(84,84*$ratio); ?>" width="84" height="<?php echo 84*$ratio ?>" alt="<?php echo $this->escapeHtml($_item->getName()) ?>" /></a>
<div class="product-details">
<h3 class="product-name"><a href="<?php echo $_item->getProductUrl() ?>"><?php echo $this->escapeHtml($_item->getName()) ?></a></h3>
<?php echo $this->getPriceHtml($_item, true) ?>
<button type="button" title="<?php echo $this->__('Add to Cart') ?>" class="button btn-cart" onclick="setLocation('<?php echo $this->getAddToCartUrl($_item) ?>')"><span><span><?php echo $this->__('Add to Cart') ?></span></span></button>
<ul class="add-to-links">
<?php if ($this->helper('wishlist')->isAllow()) : ?>
<li><a href="<?php echo $this->getAddToWishlistUrl($_item) ?>" class="link-wishlist"><?php echo $this->__('Add to Wishlist') ?></a></li>
<?php endif; ?>
<?php if($_compareUrl=$this->getAddToCompareUrl($_item)): ?>
<li><span class="separator">|</span> <a href="<?php echo $_compareUrl ?>" class="link-compare"><?php echo $this->__('Add to Compare') ?></a></li>
<?php endif; ?>
</ul>
</div>
</li>
<?php endforeach; ?>
</ul>
<script type="text/javascript">decorateList('crosssell-products-list', 'none-recursive')</script>
</div>
<?php endif; ?>
2016年12月2日編集:
これは、特に異なるクロスセル製品を各製品に個別に割り当てたい場合に最適なソリューションです。私の場合-すべての商品に「完全同一」のクロスセル商品を入れたいのですが、季節に応じてそれを変更できるようにしたいので、チェックアウトで追加のステップを行うことにしました(Murtuzaが提供するソリューション)以下のZabuawala)は、このために私が作成した特別なカテゴリの製品を表示しています。Murtuza Zabuawalaは素晴らしい仕事をしました。私はここで最後のステップを逃しています:
特定のカテゴリの製品を表示するコードを挿入すると、次のようになります。
$block = $this->getLayout()->createBlock('catalog/product_list')->setCategoryId(157)->setTemplate('catalog/product/list.phtml'); $this->getLayout()->getBlock('content')->append($block);
次のエラーメッセージが表示されます。
> There has been an error processing your request
>
>
> SQLSTATE[42000]: Syntax error or access violation: 1064 You have an
> error in your SQL syntax; check the manual that corresponds to your
> MySQL server version for the right syntax to use near ')' at line 1,
> query was: SELECT `mg_catalog_category_entity`.* FROM
> `mg_catalog_category_entity` WHERE (entity_id =)
>
> Trace:
> #0 /home/mystore/public_html/lib/Varien/Db/Statement/Pdo/Mysql.php(110):
> Zend_Db_Statement_Pdo->_execute(Array)
> #1 /home/mystore/public_html/app/code/core/Zend/Db/Statement.php(291): Varien_Db_Statement_Pdo_Mysql->_execute(Array)
> #2 /home/mystore/public_html/lib/Zend/Db/Adapter/Abstract.php(480): Zend_Db_Statement->execute(Array)
> #3 /home/mystore/public_html/lib/Zend/Db/Adapter/Pdo/Abstract.php(238):
> Zend_Db_Adapter_Abstract->query('SELECT `mg_cata...', Array)
> #4 /home/mystore/public_html/lib/Varien/Db/Adapter/Pdo/Mysql.php(428): Zend_Db_Adapter_Pdo_Abstract->query('SELECT `mg_cata...', Array)
> #5 /home/mystore/public_html/lib/Zend/Db/Adapter/Abstract.php(756): Varien_Db_Adapter_Pdo_Mysql->query(Object(Varien_Db_Select), Array)
> #6 /home/mystore/public_html/app/code/core/Mage/Eav/Model/Entity/Abstract.php(943):
> Zend_Db_Adapter_Abstract->fetchRow(Object(Varien_Db_Select))
> #7 /home/mystore/public_html/app/code/core/Mage/Catalog/Model/Resource/Abstract.php(698):
> Mage_Eav_Model_Entity_Abstract->load(Object(Mage_Catalog_Model_Category),
> Object(Mage_Catalog_Model_Category), NULL)
> #8 /home/mystore/public_html/app/code/core/Mage/Core/Model/Abstract.php(225):
> Mage_Catalog_Model_Resource_Abstract->load(Object(Mage_Catalog_Model_Category),
> Object(Mage_Catalog_Model_Category), NULL)
> #9 /home/mystore/public_html/app/code/core/Mage/Catalog/Block/Product/List.php(80):
> Mage_Core_Model_Abstract->load(Object(Mage_Catalog_Model_Category))
> #10 /home/mystore/public_html/app/code/core/Mage/Catalog/Block/Product/List.php(142):
> Mage_Catalog_Block_Product_List->_getProductCollection()
> #11 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(918):
> Mage_Catalog_Block_Product_List->_beforeToHtml()
> #12 /home/mystore/public_html/app/code/core/Mage/Core/Block/Text/List.php(43):
> Mage_Core_Block_Abstract->toHtml()
> #13 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(919):
> Mage_Core_Block_Text_List->_toHtml()
> #14 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(637):
> Mage_Core_Block_Abstract->toHtml()
> #15 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(581):
> Mage_Core_Block_Abstract->_getChildHtml('content', true)
> #16 /home/mystore/public_html/app/design/frontend/smartwave/porto/template/page/1column.phtml(49):
> Mage_Core_Block_Abstract->getChildHtml('content')
> #17 /home/mystore/public_html/app/code/core/Mage/Core/Block/Template.php(241):
> include('/home/mystore/pu...')
> #18 /home/mystore/public_html/app/code/core/Mage/Core/Block/Template.php(272):
> Mage_Core_Block_Template->fetchView('frontend/smartw...')
> #19 /home/mystore/public_html/app/code/core/Mage/Core/Block/Template.php(286):
> Mage_Core_Block_Template->renderView()
> #20 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(919):
> Mage_Core_Block_Template->_toHtml()
> #21 /home/mystore/public_html/app/code/core/Mage/Core/Model/Layout.php(555):
> Mage_Core_Block_Abstract->toHtml()
> #22 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php(390):
> Mage_Core_Model_Layout->getOutput()
> #23 /home/mystore/public_html/app/code/community/TM/SuggestPage/controllers/IndexController.php(32):
> Mage_Core_Controller_Varien_Action->renderLayout()
> #24 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php(418):
> TM_SuggestPage_IndexController->indexAction()
> #25 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(250):
> Mage_Core_Controller_Varien_Action->dispatch('index')
> #26 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Front.php(172):
> Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))
> #27 /home/mystore/public_html/app/code/core/Mage/Core/Model/App.php(354):
> Mage_Core_Controller_Varien_Front->dispatch()
> #28 /home/mystore/public_html/app/Mage.php(684): Mage_Core_Model_App->run(Array)
> #29 /home/mystore/public_html/index.php(87): Mage::run('', 'store')
> #30 {main}
俺の
app / code / community / TM / SuggestPage / controllers / IndexControlle r.php
このようになります:
<?php class TM_SuggestPage_IndexController extends Mage_Core_Controller_Front_Action { public function indexAction() { $this->loadLayout() ->_initLayoutMessages('checkout/session') ->_initLayoutMessages('catalog/session'); $block2 = $this->getLayout()->createBlock('checkout/cart_coupon')->setTemplate('checkout/cart/coupon.phtml'); $this->getLayout()->getBlock('content')->append($block2); $_product = Mage::getModel('catalog/product')->load(1); //here 1 is product Id $block = $this->getLayout()->createBlock('catalog/product_list')->setCategoryId(157)->setTemplate('catalog/product/list.phtml'); $this->getLayout()->getBlock('content')->append($block); $this->renderLayout(); } }
ときに私が代わりに次のコードを試してみました(中:app/code/community/TM/SuggestPage/controllers/IndexController.php
):
**
$category = Mage::getModel('catalog/category')->load(190);
$block = $this->getLayout()->createBlock('catalog/product_list')->setCategory($category)->setTemplate('catalog/product/list.phtml'); $this->getLayout()->getBlock('content')->append($block);
**
- それは私にこのエラーを与えました:
SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your
1行目でnear ')'を使用するための正しい構文のMySQLサーバーバージョンクエリは次のとおりです:SELECT
mg_catalog_category_entity
。* FROMmg_catalog_category_entity
WHERE(entity_id =)Trace: #0 /home/mystore/public_html/lib/Varien/Db/Statement/Pdo/Mysql.php(110):
Zend_Db_Statement_Pdo-> _ execute(Array)#1 /home/mystore/public_html/app/code/core/Zend/Db/Statement.php(291):Varien_Db_Statement_Pdo_Mysql-> _ execute(Array)#2 / home / mystore / public_html / lib /Zend/Db/Adapter/Abstract.php(480):Zend_Db_Statement-> execute(Array)#3 /home/mystore/public_html/lib/Zend/Db/Adapter/Pdo/Abstract.php(238):Zend_Db_Adapter_Abstract-> query( 'SELECT
mg_cata...', Array) #4 /home/mystore/public_html/lib/Varien/Db/Adapter/Pdo/Mysql.php(428): Zend_Db_Adapter_Pdo_Abstract->query('SELECT
mg_cata ... '、Array)#5 /home/mystore/public_html/lib/Zend/Db/Adapter/Abstract.php(756):Varien_Db_Adapter_Pdo_Mysql-> query(Object(Varien_Db_Select)、Array)#6 / home / mystore /public_html/app/code/core/Mage/Eav/Model/Entity/Abstract.php(943):Zend_Db_Adapter_Abstract-> fetchRow(Object(Varien_Db_Select))#7 / home / mystore / public_html / app / code / core / Mage /Catalog/Model/Resource/Abstract.php(698):Mage_Eav_Model_Entity_Abstract-> load(Object(Mage_Catalog_Model_Category)、Object(Mage_Catalog_Model_Category)、NULL)#8 / home / mystore / public_html / app / code / core / Mage / Core / Model / Abstract.php(225):Mage_Catalog_Model_Resource_Abstract-> load(Object(Mage_Catalog_Model_Category)、Object(Mage_Catalog_Model_Category)、NULL)#9 / home / mystore / public_html / app / code / core / Mage / Catalog / Block / Product / List .php(80):Mage_Core_Model_Abstract-> load(Object(Mage_Catalog_Model_Category))#10 /home/mystore/public_html/app/code/core/Mage/Catalog/Block/Product/List.php(142):Mage_Catalog_Block_Product_List-> _ getProductCollection()#11 / home /mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(918):Mage_Catalog_Block_Product_List-> _ beforeToHtml()#12 / home / mystore / public_html / app / code / core / Mage / Core / Block /Text/List.php(43):Mage_Core_Block_Abstract-> toHtml()#13 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(919):Mage_Core_Block_Text_List-> _ toHtml() #14 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(637):Mage_Core_Block_Abstract-> toHtml()#15 / home / mystore / public_html / app / code / core / Mage /Core/Block/Abstract.php(581):Mage_Core_Block_Abstract->_getChildHtml( 'content'、true)#16 /home/mystore/public_html/app/design/frontend/smartwave/porto/template/page/1column.phtml(49):Mage_Core_Block_Abstract-> getChildHtml( 'content')#17 / home / mystore / public_html / app / code / core / Mage / Core / Block / Template.php(241):include( '/ home / mystore / pu ...')#18 / home / mystore / public_html / app / code / core / Mage / Core / Block / Template.php(272):Mage_Core_Block_Template-> fetchView( 'frontend / smartw ...')#19 / home / mystore / public_html / app / code / core / Mage / Core / Block / Template.php(286):Mage_Core_Block_Template-> renderView()#20 /home/mystore/public_html/app/code/core/Mage/Core/Block/Abstract.php(919):Mage_Core_Block_Template-> _ toHtml()# 21 /home/mystore/public_html/app/code/core/Mage/Core/Model/Layout.php(555):Mage_Core_Block_Abstract->toHtml()#22 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php(390):Mage_Core_Model_Layout-> getOutput()#23 / home / mystore / public_html / app / code / community / TM / SuggestPage / controllers / IndexController.php(33):Mage_Core_Controller_Varien_Action-> renderLayout()#24 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Action.php( 418):TM_SuggestPage_IndexController-> indexAction()#25 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(250):Mage_Core_Controller_Varien_Action-> dispatch( 'index') #26 /home/mystore/public_html/app/code/core/Mage/Core/Controller/Varien/Front.php(172):Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))#27 /home/mystore/public_html/app/code/core/Mage/Core/Model/App.php(354):Mage_Core_Controller_Varien_Front-> dispatch()#28 / home / mystore / public_html / app / Mage.php(684):Mage_Core_Model_App-> run(Array)#29 /home/mystore/public_html/index.php(87):Mage :: run( ''、 'store')#30 {メイン}Error log record number: 573016373867
私のController.phpは次のようになっていると思いますか?
<?php class TM_SuggestPage_IndexController extends Mage_Core_Controller_Front_Action { public function indexAction() { $this->loadLayout() ->_initLayoutMessages('checkout/session') ->_initLayoutMessages('catalog/session'); $block2 = $this->getLayout()->createBlock('checkout/cart_coupon')->setTemplate('checkout/cart/coupon.phtml'); $this->getLayout()->getBlock('content')->append($block2); $_product = Mage::getModel('catalog/product')->load(1); //here 1 is product Id $category = Mage::getModel('catalog/category')->load(190); $block = $this->getLayout()->createBlock('catalog/product_list')->setCategory($category)->setTemplate('catalog/product/list.phtml');
$ this-> getLayout()-> getBlock( 'content')-> append($ block);
$this->renderLayout(); } }
2016年12月29日編集:
Murtuza Zabuawalaによって投稿されたソリューションは素晴らしいです!まだ必要なことは、実際のクロスセルアイテムの代わりに、特定のカテゴリの製品を呼び出す(表示する)ためのコードを挿入することだけです。それを行う方法はありますか?