Magento给新产品页面添加分页

本文介绍如何让magento创建一个带分页功能的新到产品页面,方便我们在首页或者其它CMS Page调用和展示新到产品。

在Magento我们经常有的做法是建立一个可以调用新产品的block,然后通过:

{{block type="catalog/product_new" column_count="6" products_count="100" name="home.catalog.product.new" alias="product_homepage" template="catalog/product/new.phtml"}}

调用,这样就可以在Magento首页显示新到产品 或者其他位置调用,前提要有添加新产品并设置新产品期间了。

现在是要让Magento创建一个带分页功能的新到产品展示Page,自动展示有设置了“Set Product as New from Date – Set Product as New to Date”的新到产品。

话入正题。Magento在CMS Page添加带分页功能的新到产品页面步骤如下;

创建路径:app/code/local/Mage/Catalog/Block/Product

创建文件:app/code/local/Mage/Catalog/Block/Product/New.php

New.php将覆盖掉magento core里的New.php,所以如果原来New.php有在使用的话local的这个文件另外命名区分开。

添加以下内容到New.php

<?php
//[email protected]
class Mage_Catalog_Block_Product_New extends Mage_Catalog_Block_Product_List
{
   function get_prod_count()
   {
      //unset any saved limits
      Mage::getSingleton(‘catalog/session‘)->unsLimitPage();
      return (isset($_REQUEST[‘limit‘])) ? intval($_REQUEST[‘limit‘]) : 12;
   }// get_prod_count

   function get_cur_page()
   {
      return (isset($_REQUEST[‘p‘])) ? intval($_REQUEST[‘p‘]) : 1;
   }// get_cur_page

   /**
    * Retrieve loaded category collection
    *
    * @return Mage_Eav_Model_Entity_Collection_Abstract
   **/
   protected function _getProductCollection()
   {
      $todayDate  = Mage::app()->getLocale()->date()->toString(Varien_Date::DATETIME_INTERNAL_FORMAT);

      $collection = Mage::getResourceModel(‘catalog/product_collection‘);
      $collection->setVisibility(Mage::getSingleton(‘catalog/product_visibility‘)->getVisibleInCatalogIds());

      $collection = $this->_addProductAttributesAndPrices($collection)
         ->addStoreFilter()
         ->addAttributeToFilter(‘news_from_date‘, array(‘date‘ => true, ‘to‘ => $todayDate))
         ->addAttributeToFilter(‘news_to_date‘, array(‘or‘=> array(
            0 => array(‘date‘ => true, ‘from‘ => $todayDate),
            1 => array(‘is‘ => new Zend_Db_Expr(‘null‘)))
         ), ‘left‘)
         ->addAttributeToSort(‘news_from_date‘, ‘desc‘)
         ->setPageSize($this->get_prod_count())
         ->setCurPage($this->get_cur_page());

      $this->setProductCollection($collection);

      return $collection;
   }// _getProductCollection
}// Mage_Catalog_Block_Product_New
?>

保存后,创建CMS里的新到产品列表Page。添加后,设置Design的内容为以下内容:

<reference name="content">
   <block type="catalog/product_new" name="product_new" template="catalog/product/list.phtml">
      <action method="setCategoryId"><category_id>10</category_id></action>
      <action method="setColumnCount"><column_count>6</column_count></action>
      <action method="setProductsCount"><count>0</count></action>
      <block type="catalog/product_list_toolbar" name="product_list_toolbar" template="catalog/product/list/toolbar.phtml">
         <block type="page/html_pager" name="product_list_toolbar_pager" />
         <action method="setDefaultGridPerPage"><limit>12</limit></action>
         <action method="addPagerLimit"><mode>grid</mode><limit>12</limit></action>
         <action method="addPagerLimit"><mode>grid</mode><limit>24</limit></action>
         <action method="addPagerLimit"><mode>grid</mode><limit>36</limit></action>
         <action method="addPagerLimit"><mode>grid</mode><limit>48</limit></action>
         <action method="addPagerLimit" translate="label"><mode>grid</mode><limit>all</limit><label>All</label></action>
      </block>
      <action method="addColumnCountLayoutDepend"><layout>one_column</layout><count>6</count></action>
      <action method="setToolbarBlockName"><name>product_list_toolbar</name></action>
   </block>
</reference>

这样就可以保存查看效果了。以下简要备记几点说明:

<block type="catalog/product_new" name="product_new" template="catalog/product/list.phtml">

设置块的类型和使用的模版文件,这个文件也是产品列表页用的。“catalog/product_new” 这个就是更换了的New.php。

<action method="setCategoryId"><category_id>10</category_id></action>

setCategoryId 设置目录ID,可以是网站的根目录ID,或者某目录。

<action method="setColumnCount"><column_count>6</column_count></action>

setColumnCount 新到产品的Page产品每页产品数为6

<action method="setProductsCount"><count>0</count></action>

setProductsCount 设为0的话就是该指定目录的所有产品,否者按限定数

<block type="catalog/product_list_toolbar" name="product_list_toolbar" template="catalog/product/list/toolbar.phtml">
<block type="page/html_pager" name="product_list_toolbar_pager" />

为新到产品列表页面添加目录页的工具条和分页

<action method="setDefaultGridPerPage"><limit>12</limit></action>

setDefaultGridPerPage 配置工具栏的产品显示数

<action method="addPagerLimit"><mode>grid</mode><limit>12</limit></action>

配置分页的产品数

<action method="addColumnCountLayoutDepend"><layout>one_column</layout><count>6</count></action>

one_column 布局定为6列

<action method="setToolbarBlockName"><name>product_list_toolbar</name></action>

工具条的命名

Page的Design部分设置好后,Content部分随便设下,保存,就能查看效果了。

这篇Magento添加新产品在CMS Page 是翻译老外的,经实际操作完全可行。

时间: 2024-10-24 15:17:26

Magento给新产品页面添加分页的相关文章

如何给magento的产品页面添加返回按钮

如何给magento的产品页面添加返回按钮,最模板提供教程 第一步: 打开 E:\xampp\htdocs\magento\skin\frontend\default\bluescale\css\styles.css 在底部添加返回按钮css代码,如下: /* Back Button */ .product-b 如何给magento的产品页面添加返回按钮,最模板提供教程 第一步: 打开 E:\xampp\htdocs\magento\skin\frontend\default\bluescale

使用jquery插件kkpager为页面添加分页

首先下载kkpager插件:https://github.com/pgkk/kkpager 1.将下载下来的js和css拷贝到项目中,在需要分页的页面引入kkpager插件所需的js和css,如下: <script type="text/javascript" src="js/kkpager.js"></script> <script type="text/javascript" src="js/jquer

magento -- 添加新产品时状态默认为激活,库存状态默认为有库存

添加新产品时状态默认为激活 打开文件/app/code/core/Mage/Catalog/Model/Product/Status.php,注释掉“Please Select” [php] view plaincopy /** * Retrieve option array with empty value * * @return array */ static public function getAllOptions() { $res = array( /* array( 'value' 

.NET生成静态页面并分页

因为公司的产品用asp开发, 前一段时间用asp写了一个生成静态页面并分页的程序,但缘于对.net的热爱,写了这个.net下的生成静态页面并分页的程序. 主要的原理就是替换模板里的特殊字符. 1.静态模板页面 template.html,主要是定义了一些特殊字符,用来被替换. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/TR/html4/loose.dt

采用AJAX + history api做无刷新页面的分页

大家都知道浏览器有一个history对象是用来保存浏览历史的,比如一个窗口访问了两个个页面,那么history.length属性等于2. history api在H5时代新增了两个方法,pushState和replaceState 从名字就可以知道一个是新增一条记录一个是改变当前那么记录. 用AJAX加history做分页的好处就是既提高了用户体验,支持前进后退,加快页面加载速度又对搜索引擎十分友好 首先我们来判断浏览器是否支持pushState/replaceState if(!!(windo

iOS_20_微博新特性页面

最终效果图: BeyondAppDelegate.m // // BeyondAppDelegate.m // 20_帅哥no微博 // // Created by beyond on 14-8-3. // Copyright (c) 2014年 com.beyond. All rights reserved. // #import "BeyondAppDelegate.h" #import "BeyondViewController.h" #import &quo

html:打开新的页面

在html页面中,打开一个新的页面,有两种方式: 一.利用超链接 <a href="newurl">新页面</a> 上面代码添加了一个新链接,点击链接时会打开newurl对应的页面. 注意这种情况下,新的页面会在原页面的浏览器窗口(或tab标签页)上显示,前面页面会被覆盖. 如果需要在一个新的浏览器窗口(或新的标签页)打开新的url,应该采用如下的写法. <a href="newurl" target="_blank"

Sharepoint2013 列表的NewForm 页面添加一个 保存新建 按钮

昨天一同事问我如何在sharepoint2013的NewForm.aspx页面上添加一个 save and new的button.实现save 和new的功能,save的功能和默认的save按钮效果一至. 效果如图: 这里的思路如下: 1)用juqery来动态添加一个saveandnew的button 2)新建按钮的click事件将要调用默认save 按钮的click方法 3)新按钮的click事件后页面跳转主要取决于url的Source参数,所以我们必须改写获取该参数的方法,该参数的读取是在i

iOS开发实用技巧—项目新特性页面的处理

iOS开发实用技巧篇—项目新特性页面的处理 说明:本文主要说明在项目开发中会涉及到的最最简单的新特性界面(实用UIScrollView展示多张图片的轮播)的处理. 代码示例: 新建一个专门的处理新特性界面的控制器,可以实用代码也可以用xib,在这里实用纯代码方式,创建一个控制器NewfeatureViewController. 头文件代码: 1 // 2 // JMNewfeatureViewController.h 3 // 4 5 #import <UIKit/UIKit.h> 6 7 t