1

私は自分自身を見つけることができない問題を抱えているので、助けていただければ幸いです。

JSONデータで満たされた動的カートがあります。カートでは、送料も同じ json データから入力されます。スクリプト自体は、メソッドが使用可能な場合に機能します。その国で配送方法が利用できない場合、スクリプトは「利用できません」などと言う必要があります。代わりに、未定義のエラーが返され、カートが機能しなくなります。いくつかの検索の後、ユーザーが国 A (カートでサポートされている) から来たときに、変数「methods」が Json 文字列に存在することがわかりました。ユーザーが国 B (サポートされていない) から来た場合、json 文字列に変数 "methods" が存在しません。明らかにそれがエラーの原因です。だから私が達成しようとしているのは、変数「メソッド」が存在するかどうかを確認することです。typeofを使用するようないくつかの答えが見つかりました、

私のスクリプト

 <script type="text/javascript">

        function getPriceDynamicCart(price){
          price = parseFloat(price).toFixed(2);
            price = '€ ' + price.replace('.', ',');
          return price;
        }
        function loadDynamicCart(){
          var url = "{{ '/cart/' | url }}?format=json";

          $.getJSON(url,function(data){

            var cartHtml = '';
            var priceTotal = 0;
            var foundShipment = false;

             $.each(data.cart.products, function(index, product){                  

              priceTotal = priceTotal + parseFloat(product.price.price_incl);
              productTitleLimit = jQuery.trim(product.fulltitle).substring(0, 19);

              cartHtml = cartHtml +
                '<div class="cart-product"><div class="cart-quantity">' +product.quantity+'&nbsp;x&nbsp;</div><div class="cart-title"><a href="'+ product.url +'" alt="'+ product.fulltitle + '" title="'+ product.fulltitle + '">' + productTitleLimit + '</a></div><div class="cart-price">' + getPriceDynamicCart(product.price.price_incl) + '</div></div>';
            });

            $.each(data.cart.shipping.methods, function(index, method){

              if(!foundShipment && !method.cod && !method.pickup) {
                priceTotal = priceTotal + parseFloat(method.price.price_incl);
                cartHtml = cartHtml +
                  '<div class="cart-shipping"><a class="vracht" style="cursor:pointer;" rel="nofollow">Verzendkosten:<br />(Vervallen bij afhalen)</a><div class="cart-price"> ' + getPriceDynamicCart(method.price.price_incl) + '</div></div>';

                foundShipment = true;                
              }
            });

            cartHtml = cartHtml +
              '<div class="cart-total"><div class="total">Totaal(incl. btw): <span>' + getPriceDynamicCart(priceTotal) + '</span></div>';

            $('#dynamic_cart').html(cartHtml);

          });
        }

        $().ready(function(){
          loadDynamicCart();
        });
      </script>
4

2 に答える 2

3
if(data.cart.shipping.methods !== undefined){

    $.each(data.cart.shipping.methods, function(index, method){

          if(!foundShipment && !method.cod && !method.pickup) {
            priceTotal = priceTotal + parseFloat(method.price.price_incl);
            cartHtml = cartHtml +
              '<div class="cart-shipping"><a class="vracht" style="cursor:pointer;" rel="nofollow">Verzendkosten:<br />(Vervallen bij afhalen)</a><div class="cart-price"> ' + getPriceDynamicCart(method.price.price_incl) + '</div></div>';

            foundShipment = true;                
          }
        });
}else{
  cartHtml = cartHtml +
              '<div class="cart-shipping"><a class="vracht" style="cursor:pointer;" rel="nofollow">Verzendkosten:<br />(Vervallen bij afhalen)</a><div class="cart-price">**Anything you care to write**</div></div>';
}

それはうまくいくはずです。

編集、cartHtml 変数を設定するための else ステートメントを追加したので、将来の使用により柔軟に対応できます。

于 2012-11-06T17:28:32.487 に答える
0

data.cart.shipping.methodsを呼び出す前に、プロパティが null / undefined でないことを確認できeachます。

if (data.cart.shipping.methods) {
    $.each(data.cart.shipping.methods, function(index, method){
    //...
    }
}
于 2012-11-06T17:27:27.767 に答える