2014-02-12 55 views
0

好吧,如果這個問題已經回答,我很抱歉,我已經搜索,沒有找到符合我的情況的令人滿意的答案。Magento不承認自定義的JavaScript功能

這裏的情況是:

我有一個類別顯示產品的自定義模板文件,該列表中的部分是直接將產品添加到購物車從分類頁面指定數量的能力。爲了做到這一點,我寫了一個函數,重寫「添加到購物車」按鈕的目標行,提交請求,然後再次將該按鈕重新寫回原始版本(請參閱下面的代碼)。我遇到的問題是,每次單擊按鈕時,我都會在調試面板中看到一個錯誤,指出customAddToCart is not defined。但是,如果您查看下面的產品列表模板的代碼,您可以看到該函數甚至在生成列表之前就已定義(順便說一下,我在頁面底部獲得了相同的錯誤)。

如果有人可以闡明爲什麼javascript函數會被列入與列表相同的頁面時未定義...我可以確定使用一些幫助。

<?php 
/** 
* Product list template 
* 
* @see Mage_Catalog_Block_Product_List 
*/ 
?> 
<?php 
    $_productCollection=$this->getLoadedProductCollection(); 
    $_helper = $this->helper('catalog/output'); 
?> 
<script type="text/javascript"> 
    function customAddToCart(product_id, url){ 
     var qty = document.getElementById('qty_input_'+product_id).value; 
     document.getElementById('addtocartbutton_'+product_id).setAttribute('onclick', "setLocation(" + url + "/qty/" + qty ")"); 
     document.getElementById('addtocartbutton_'+product_id).click(); return false; 
     document.getElementById('addtocartbutton_'+product_id).setAttribute('onclick', "customAddToCart(" + product_id + ", " + url + ")"); 
    } 
</script> 
<?php if(!$_productCollection->count()): ?> 
<p class="note-msg"><?php echo $this->__('There are no products matching the selection.') ?></p> 
<?php else: ?> 
<div class="category-products"> 
    <?php // List mode ?> 
    <?php if($this->getMode()!='grid'): ?> 
    <ol class="products-list" id="products-list"> 
    <?php foreach ($_productCollection as $_product): ?> 
     <li class="item"> 
      <?php // Product Image ?> 
      <a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" class="product-image"><img src="<?php echo $this->helper('catalog/image')->init($_product, 'small_image')->constrainOnly(TRUE)->keepAspectRatio(TRUE)->keepFrame(FALSE)->resize(230, null); ?>" width="230" alt="<?php echo $this->stripTags($this->getImageLabel($_product, 'small_image'), null, true) ?>" /></a> 
      <?php // Product description ?> 
      <div class="product-shop"> 
       <div class="f-fix"> 
        <?php $_productNameStripped = $this->stripTags($_product->getName(), null, true); ?> 
        <h2 class="product-name"><a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $_productNameStripped; ?>"><?php echo $_helper->productAttribute($_product, $_product->getName() , 'name'); ?></a></h2> 
        <?php if($_product->getRatingSummary()): ?> 
        <?php echo $this->getReviewsSummaryHtml($_product) ?> 
        <?php endif; ?> 
        <?php echo $this->getPriceHtml($_product, true) ?>      
        <div class="desc std"> 
         <?php echo $_helper->productAttribute($_product, $_product->getShortDescription(), 'short_description') ?> 
         <a href="<?php echo $_product->getProductUrl() ?>" title="<?php echo $_productNameStripped ?>" class="link-learn"><?php echo $this->__('Learn More') ?></a> 
        </div> 
        <ul class="add-to-links"> 
         <?php if ($this->helper('wishlist')->isAllow()) : ?> 
          <li><a href="<?php echo $this->helper('wishlist')->getAddUrl($_product) ?>" class="link-wishlist"><?php echo $this->__('Add to Wishlist') ?></a></li> 
         <?php endif; ?> 
         <?php if($_compareUrl=$this->getAddToCompareUrl($_product)): ?> 
          <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 class="add-to-cart-options"> 
        <?php if($_product->isSaleable()): ?> 
        <?php if(!($_product->getTypeInstance(true)->hasRequiredOptions($_product) || $_product->isGrouped())){ ?> 
         <label for="qty_input">Quantity: </label> 
         <input type="text" class="spinner qty-input" name="qty_input" id="qty_input_<?php echo $_product->getId(); ?>" /> 
         <?php /*<p><button type="button" title="<?php echo $this->__('Add to Cart') ?>" class="button btn-cart" onclick="setLocation('<?php echo $this->getAddToCartUrl($_product) ?>')"><span><span><?php echo $this->__('Add to Cart') ?></span></span></button></p> */ ?> 
         <button type="button" class="button" onclick="javascript:customAddToCart(<?php echo $_product->getId(); ?>, '<?php echo $this->getAddToCartUrl($_product); ?>')"><span><span><?php echo $this->__('Add to Cart'); ?></span></span></button> 
        <?php } else { ?> 
         <button type="button" class="button" id="addtocartbutton_<?php echo $_product->getId(); ?>" onclick="setLocation('<?php echo $this->getAddToCartUrl($_product) ?>')"><span><span><?php echo $this->__('Add to Cart'); ?></span></span></button> 
        <?php } ?> 
        <?php else: ?> 
        <p class="availability out-of-stock"><span><?php echo $this->__('Out of stock') ?></span></p> 
       <?php endif; ?> 
       </div> 
      </div> 
     </div> 
    </li> 
<?php endforeach; ?> 
</ol>  
<script type="text/javascript">decorateList('products-list', 'none-recursive')</script> 

<?php else: ?> 

正如你所看到的,功能顯然是在頁面的頂部定義,那麼,爲什麼這個按鈕

<button type="button" class="button" onclick="javascript:customAddToCart(<?php echo $_product->getId(); ?>, '<?php echo $this->getAddToCartUrl($_product); ?>')"><span><span><?php echo $this->__('Add to Cart'); ?></span></span></button> 

結果在控制檯中的消息說,customAddToCart is not defined我不知道。

+1

嘗試在'CDATA'中確定JavaScript範圍。如果您不知道我的意思,請參閱base/default/template文件,其中腳本的範圍是CDATA的註釋。 –

+0

謝謝你的提示,我認爲這是你推薦和wbaaron在下面建議的組合,但我能夠得到它的工作。 – Chris

回答

2

有關「意外字符串」的錯誤嗎?函數第二行中的連接缺少最後一個加號。

更新

"/qty/" + qty ")" 

"/qty/" + qty + ")" 

和刷新。