Hiển thị nhiều sản phẩm hơn nữa.

Thảo luận các vấn đề vể cài đặt và sử dụng Joomla! và các thành phần mở rộng của Joomla!
Nội quy chuyên mục
Thành viên đăng quảng cáo trong chuyên mục này sẽ bị xóa toàn bộ bài viết và cấm vĩnh viễn tham gia Diễn đàn.

* Xem qui định đăng bài viết tại đây: Nội quy đăng bài viết
Đăng trả lời
ohieuj
Thành viên
Thành viên
Bài viết: 21
Ngày tham gia: 05/01/2012 - 12:25

Hiển thị nhiều sản phẩm hơn nữa.

Gửi bài gửi bởi ohieuj » 27/07/2012 - 17:06

Chào cả nhà.
Hiện tại e đang sử dụng Module mod_virtuemart_featureprod để hiển thị danh sách sản phẩm.
Nhưng cố định thì nó chỉ hiển thị 2 hàng và 4 cột thôi. Trong khi sản phẩm của e lại có nhiều.
Bây giờ e muốn hiển thị 5 hàng và 4 cột để sản phẩm nhiều hơn thì e phải làm thế nào ạ.
Em chân thành cảm ơn.
Chúc mọi người vui vẻ.

Hình đại diện của thành viên
TruongLe
Thành viên
Thành viên
Bài viết: 1684
Ngày tham gia: 14/09/2010 - 20:20

Re: Hiển thị nhiều sản phẩm hơn nữa.

Gửi bài gửi bởi TruongLe » 28/07/2012 - 00:08

Bạn mở Module mod_virtuemart_featureprod và thiết lập thông số như sau:

Number of displayed products: 20 (Số lượng sản phẩm muốn hiển thị)
Products per row: 4 (Số sản phẩm hiển thị trên 1 dòng)

Lưu ý:

- Chỉ có những sản phẩm nào được đánh dấu chọn Featured mới được hiển thị.

- Nếu tên hoặc ảnh của sản phẩm có kích thước chiều ngang quá lớn thì sẽ không đủ chỗ cho nhiều sản phẩm trên một dòng.
* Hãy sử dụng công cụ tìm kiếm của Diễn đàn trước khi đặt câu hỏi.
* Hãy đặt tên cho Chủ đề diễn tả đúng với nội dung để thuận tiện khi tìm kiếm.
* Hãy chia sẻ kiến thức của bạn vì không chỉ giúp được mọi người mà còn giúp mình ghi nhớ những điều đã biết!

ohieuj
Thành viên
Thành viên
Bài viết: 21
Ngày tham gia: 05/01/2012 - 12:25

Re: Hiển thị nhiều sản phẩm hơn nữa.

Gửi bài gửi bởi ohieuj » 29/07/2012 - 09:18

Vâng em cảm ơn anh.
Đoạn code đó của e như này thì e chỉnh thế nào a nhỉ ?
Đánh dấu chọn Featured để được hiển thị ở chỗ nào a nhỉ ?
Thanks a nhiều.

Mã: Chọn tất cả

<?php
if( !defined( '_VALID_MOS' ) && !defined( '_JEXEC' ) ) die( 'Direct Access to '.basename(__FILE__).' is not allowed.' );
global $mosConfig_absolute_path;

// Load the virtuemart main parse code
if( file_exists(dirname(__FILE__).'/../../components/com_virtuemart/virtuemart_parser.php' )) {
   require_once( dirname(__FILE__).'/../../components/com_virtuemart/virtuemart_parser.php' );
} else {
   require_once( dirname(__FILE__).'/../components/com_virtuemart/virtuemart_parser.php' );
}

$max_items = $params->get( 'max_items', 2 ); //maximum number of items to display
$category_id = $params->get( 'category_id', null ); // Display products from this category only
$display_style = $params->get( 'display_style', "vertical" ); // Display Style
$products_per_row = $params->get( 'products_per_row', 4 ); // Display X products per Row
$show_price = (bool)$params->get( 'show_price', 1 ); // Display the Product Price?
$show_addtocart = (bool)$params->get( 'show_addtocart', 1 ); // Display the "Add-to-Cart" Link?

require_once ( CLASSPATH. 'ps_product.php');
$ps_product = new ps_product;
$db = new ps_DB;

if ( $category_id ) {
   // BEGIN - MultiCategory Display - deneb
   $cat_ids = explode(",",$category_id);
   if (count($cat_ids) > 1){
      $multi_cats = 1;
   }
   // END - MultiCategory Display - deneb

   $q  = "SELECT DISTINCT product_sku FROM #__{vm}_product, #__{vm}_product_category_xref, #__{vm}_category WHERE \n";
   $q .= "(#__{vm}_product.product_parent_id='' OR #__{vm}_product.product_parent_id='0') \n";
   $q .= "AND #__{vm}_product.product_id=#__{vm}_product_category_xref.product_id \n";
   $q .= "AND #__{vm}_category.category_id=#__{vm}_product_category_xref.category_id \n";
   // BEGIN - MultiCategory Display - deneb
   if ($multi_cats){
      $i = 1;
      $q .= "AND (";
      foreach ($cat_ids as $cat_id){
         if ($i == count($cat_ids)){
            $q .= "(#__{vm}_category.category_id='$cat_id')";
         } else {
            $q .= "(#__{vm}_category.category_id='$cat_id') OR \n";
         }
         $i++;
      }
      $q .= ")  \n";
   } else {
      $q .= "AND #__{vm}_category.category_id='$category_id' \n";
   }
   // END - MultiCategory Display - deneb
   $q .= "AND #__{vm}_product.product_publish='Y' \n";
   $q .= "AND #__{vm}_product.product_special='Y' \n";
   if( CHECK_STOCK && PSHOP_SHOW_OUT_OF_STOCK_PRODUCTS != "1") {
      $q .= " AND product_in_stock > 0 \n";
   }
   $q .= "ORDER BY RAND() LIMIT 0, $max_items";
}
else {
   $q  = "SELECT DISTINCT product_sku FROM #__{vm}_product WHERE ";
   $q .= "(#__{vm}_product.product_parent_id='' OR #__{vm}_product.product_parent_id='0') AND vendor_id='".$_SESSION['ps_vendor_id']."' ";
   $q .= "AND #__{vm}_product.product_publish='Y' ";
   $q .= "AND #__{vm}_product.product_special='Y' ";
   if( CHECK_STOCK && PSHOP_SHOW_OUT_OF_STOCK_PRODUCTS != "1") {
      $q .= " AND product_in_stock > 0 ";
   }
   $q .= "ORDER BY RAND() LIMIT 0, $max_items";
}
$db->query($q);
if( $db->num_rows() > 0 ) {
   $width = intval(100 / intval($db->num_rows()));
   ?>
   <table border="0" cellpadding="0" cellspacing="0" width="100%">
   <?php
   $i = 0;
   while($db->next_record() ){
      if ($i%2)
      $sectioncolor = "sectiontableentry2";
      else
      $sectioncolor = "sectiontableentry1";

      if( $display_style == "vertical" ) {
        ?>
         <tr align="center" class="<?php echo $sectioncolor ?>">
            <td width="<?php echo $width ?>%">
               <?php
               $ps_product->show_snapshot($db->f("product_sku"), $show_price, $show_addtocart);
               ?><br />
            </td>
         </tr>
      <?php
      }
      elseif( $display_style== "horizontal" ) {
         if( $i == 0 )
         echo "<tr>\n";
         echo "<td width=\"$width%\" align=\"center\">";
         $ps_product->show_snapshot($db->f("product_sku"), $show_price, $show_addtocart);
         echo "</td>\n";
         if( ($i+1) == $db->num_rows() )
         echo "</tr>\n";
      }
      elseif( $display_style== "table" ) {
         if( $i == 0 )
         echo "<tr>\n";
         echo "<td width=\"$width%\" align=\"center\">";
         $ps_product->show_snapshot($db->f("product_sku"), $show_price, $show_addtocart);
         echo "</td>\n";
         if ( ($i+1) % $products_per_row == 0)
         echo "</tr><tr>\n";
         if( ($i+1) == $max_items )
         echo "</tr>\n";
      }
      $i++;
   }
?>
</table>
<?php
}
?>

ohieuj
Thành viên
Thành viên
Bài viết: 21
Ngày tham gia: 05/01/2012 - 12:25

Re: Hiển thị nhiều sản phẩm hơn nữa.

Gửi bài gửi bởi ohieuj » 29/07/2012 - 09:44

Em làm được rồi a ah.
Cảm ơn anh TruongLe và mọi người nhé.
Chúc một ngày tốt lành.

Đăng trả lời
  • Các chủ đề liên quan
    Trả lời
    Xem
    Bài viết mới nhất

Quay về

Quảng cáo trên trang Web BuaXua.VN