Shopify的错误提取请求(400),使用/cart/change.js从购物车中删除商品

Bad fetch request (400) with Shopify, removing item from cart using /cart/change.js

提问人:EddieVeddarFan69 提问时间:11/10/2023 最后编辑:EddieVeddarFan69 更新时间:11/10/2023 访问量:42

问:

使用工作链接更新

我是 javascript 的新手,也使用像 stackoverflow 这样的网站。如果我缺少任何信息,或者可以更轻松地以某种方式提供帮助,请告诉我。真的让我头疼。

我为我的商店制作了一个自定义的 Shopify 它们,并尝试使用 ajax 制作一个自定义购物车抽屉来添加和删除产品。抽屉本身和添加产品都可以工作,但我无法弄清楚使用 ajax 从购物车中删除产品。我所做的一切都收到错误请求 400 错误。请记住,我的代码中的尝试可能很遥远,或者遗漏了一些非常简单的东西 - 无论哪种方式,我都无法弄清楚,并希望得到任何指导。

这是链接: https://nwdc3mgqou964ccw-72877768986.shopifypreview.com

如果您点击首页上的产品,并将其添加到购物车,购物车抽屉将弹出并添加产品。

JS 和 HTML 如下。

// Open / Close Cart Bullshit
const openBtn = document.getElementById('open_cart_btn')
const cart = document.getElementById('sidecart')
const closeBtn = document.getElementById('close_btn')
const backdrop = document.querySelector('.backdrop')

openBtn.addEventListener('click', openCart)
closeBtn.addEventListener('click', closeCart)
backdrop.addEventListener('click', closeCart)

// Open Cart
function openCart(){
    cart.classList.add('open')
    backdrop.classList.add('show')
}

// Close Cart
function closeCart(){
  cart.classList.remove('open')
  backdrop.classList.remove('show')
}

// Event delegation for the close button
document.querySelector('.cart_content').addEventListener('click', function (event) {
  const closeBtn = event.target.closest('.close_btn');
  if (closeBtn) {
      closeCart();
  }
});

async function updateCartDrawer() {

      const res = await fetch("/?section_id=cart-drawer");
    
      const text = await res.text();
      const html = document.createElement('div');
      html.innerHTML = text;

      const newCartContent = html.querySelector(".cart_content");
      const cartContent = document.querySelector(".cart_content");

      if (cartContent && newCartContent) {
          cartContent.innerHTML = newCartContent.innerHTML;
      }
}

const addToCartForms = document.querySelectorAll('form[action="/cart/add"]');

  addToCartForms.forEach((form) => {
  form.addEventListener("submit", async (event) => {
    //Prevent Normal Submission
    event.preventDefault();

    //Submit form with AJax
    await fetch("/cart/add", {
    method: "post", 
    body: new FormData(form), 
    });

    // Update cart
    await updateCartDrawer();

    // Open cart drawer when add to cart
    cart.classList.add('open')
    backdrop.classList.add('show')
   
    // Get new cart object
    const res = await fetch("/cart.json");
    const updatedCart = await res.json();
    
    // Update cart count
    document.querySelectorAll(".cart-count").forEach((el) => {
    el.textContent = updatedCart.item_count;
    });
  });
});


// Remove Item

document.querySelector('.cart_content').addEventListener('click', async function (event) {
  const removeItemBtn = event.target.closest('.remove_item');
  if (removeItemBtn) {
    event.preventDefault();

    const productId = removeItemBtn.getAttribute('data-product-id');
    
    // Make an AJAX request to remove the item from the cart

    const response = await fetch("/cart/change.js", {
      method: "post",
      body: JSON.stringify({ productId }), // Send the product ID or relevant data
      headers: {
        'Content-Type': 'application/json',
      },
    });

    if (response.ok) {
      // Item removed successfully, update the cart
      await updateCartDrawer();
    }
  }
});

<!-- Backdrop --> 
<div class="backdrop"></div>
<!-- Side Cart -->
<div id="sidecart" class="sidecart">
   <div class="cart_content" id="cart_content">
      <div class="cart_header">
         <a href="/cart" class="header__icon-wrapper tap-area tdf_cart_icon" aria-label="Cart" data-no-instant="">
            <svg focusable="false" width="20" height="18" class="icon icon--header-cart" viewBox="0 0 20 18">
               <path d="M3 1h14l1 16H2L3 1z" fill="none" stroke="currentColor" stroke-width="2"></path>
               <path d="M7 4v0a3 3 0 003 3v0a3 3 0 003-3v0" fill="none" stroke="currentColor" stroke-width="2"></path>
            </svg>
         </a>
         <div class="header_title">
            <h2> Cart </h2>
             <span style="margin-top:-55px;" id="items_sum" class="cart-link__bubble{% if cart.item_count > -1 %} cart-link__bubble--visible{% endif %}">{{ cart.item_count }}</span>
         </div>
         <span id="close_btn" class="close_btn"> &times; </span>
      </div>

         <div class="cart-counter" id="sidecart-counter"> 
        $0 <progress class="colored" max="7500" value="{{ cart.total_price }}"></progress> $75
       <br> {% if cart.items.size == 0 %}Add items to your cart to receive free shipping.{% endif %}{% if cart.items.size != 0 %}{% if cart.total_price >= 7500 %} You've got free shipping!{% elsif cart.total_price < 7500 %}You're only {{ 7500 | minus: cart.total_price | money }} away from free shipping.{% endif %}{% endif %}
    </div>

      {% if cart.item_count == 0 %}
      <p class="cart-empty"> Your cart is empty </p>
      {% else %}

      <!-- Cart Items -->
      <div class="cart_items">
         {% form 'cart', cart %}
         {% for item in cart.items %}
         <div class="cart_item">
          <a href="{{ item.url_to_remove }}">  
           <button class="remove_item" data-product-id="{{ item.id }}">
             <span>  &times;</span> 
            </button>
</a> 
        
            <div class="item_img"> 
               <img src="{{ item.image | img_url: '200x' }}" alt="{{ item.title }}">
            </div>
            <div class="item_details">
               <h3> {{ item.title }} 
            
            
               </h3>
              
              
               <p> 
               {{ item.final_line_price | money }} 
               </p>
                
             
           {% comment %}
               <div class="qty">
                  <span>-</span>
                  <strong>1</strong>
                  <span>+</span>
               </div>
            {% endcomment %}
          

            </div>
         </div>
         {% endfor %}
        

         {% endform %}
         {% endif %}
      </div>

  
      <!-- Cart Actions -->
      <div class="cart_actions">
 
        <div class="subtotal">
            <p>SUBTOTAL:</p>
            <p> {{ cart.total_price | money }} </p>
        </div>

               <div class="discounts">
            <p> Discounts applied at checkout</p>
            {% comment %} <p>{{ cart.total_discounts | money }} </p> {% endcomment %}
        </div>
      </div>
    <div id="cart-buttons">

            <a href="https://runforcoverrecords.com/pages/store"> <button> Keep Shopping </button> </a>
                
                <a href="https://runforcoverrecords.com/checkout">
            
            <div class="lock">

                <svg style="margin-top:-3px;" focusable="false" width="17" height="17" class="icon icon--lock" viewBox="0 0 17 17">
        <path d="M2.5 7V15H14.5V7H2.5Z" stroke="currentColor" stroke-width="1.5" fill="none"></path>
        <path d="M5.5 4C5.5 2.34315 6.84315 1 8.5 1V1C10.1569 1 11.5 2.34315 11.5 4V7H5.5V4Z" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" fill="none"></path>
        <circle cx="8.5" cy="11" r="0.5" stroke="currentColor"></circle>
                </svg>
            </div>
            Checkout 
        </a>
        </div>

   </div>
</div>

我尝试使用 fetch 和 axios 使用 /cart/change.js shopify 端点从购物车中删除产品。

javascript 获取 shopify 购物车

评论


答:

0赞 hamzasgd 11/10/2023 #1

要从购物车中移除商品,您应该使用多属性 ID 并将数量设置为 0。 @eddieveddarfan69

  fetch(window.Shopify.routes.root + 'cart/update.js', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    updates: {
      47172325736730: 0
    }
  }),
})
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error('Error:', error));