Shopify - 如何在更新时更新产品价格

Shopify - How to update product price on update

我一直在努力找出在 Shopify 中将免费产品添加到购物车的最佳方法,但在他们的文档中找不到我要找的东西。

如果购物车价值为 10 英镑或更多,我需要做的是将产品添加到购物车。我已经设法添加了产品,但如何将价格更改为零?另外,我如何确保如果用户选择了更高数量的产品,他们不会获得多件免费物品而只会获得一件免费物品?希望这是有道理的。

这是我目前所拥有的,非常适合添加产品。但不改价。

*编辑:我知道如果我不能更改商品的价格,那么我可以在购物车页面级别应用固定折扣代码吗?

**编辑:想一想,折扣代码无论如何都不起作用,因为用户可以轻松删除免费产品并仍然获得折扣。也许我需要创建某种无法在商店中搜索到的隐藏产品,将其添加到购物车并禁用数量选择器。

一定有办法做到这一点,因为有可以做到这一点的应用程序。

**我不想使用应用程序

<script>
$(".cart__qty-input").blur(function() {

    location.reload();
})(jQuery);
</script>

{% assign product = all_products['free-gift'] %}

{% unless cart.item_count == 0 or product.empty? or product.variants.first.available == false %}
{% if cart.total_price >= 1000 %}
  {% assign variant_id = product.variants.first.id %}

  <script>
  (function($) {

    var cartItems = {{ cart.items | json }},
        qtyInTheCart = 0,
    cartUpdates = {};

for (var i=0; i<cartItems.length; i++) {
  if ( cartItems[i].id === {{ variant_id }} ) {
    qtyInTheCart = cartItems[i].quantity;
    break;
  }
}

if ( ( cartItems.length === 1 ) && ( qtyInTheCart > 0 ) ) {
  cartUpdates = { {{ variant_id }}: 0 }
}
else if ( ( cartItems.length >= 1 ) && ( qtyInTheCart !== 1 ) ) {
  cartUpdates = { {{ variant_id }}: 1 }
}
else {
  return;
}

var params = {
  type: 'POST',
  url: '/cart/update.js',
  data: { updates: cartUpdates },
  dataType: 'json',
  success: function(stuff) { 
    window.location.href = '/cart';
  }
};

$.ajax(params);

  })(jQuery);
  </script>
{% endif %}
{% endunless %}

您可以使用标准的 Shopify 功能来实现。

  1. 创建一个 collection,其中包含除礼品之外的所有产品。

  2. 使用以下配置创建自动折扣:

    • 类型:买 X 送 Y
    • 客户消费:最低购买金额

      • 金额:10 英镑
      • 任何项目:特定 collections
      • 搜索并添加您在第一步中创建的collection
    • 客户获得:

      • 数量:1
      • 任何项目来自:特定产品
      • 搜索并添加您想要用作礼物的产品(不属于第一步创建的 collection 的产品)
      • 折扣价:免费
      • 设置每个订单的最大使用次数:启用并将值设置为1

以上必须符合您的要求。

然后您仍然可以使用您已经创建的脚本根据购物车总数自动将礼品产品add/remove add/remove 放入购物车(如果有必要)。如果客户将礼品产品的数量更改为 2 个或更多,他将按照 Shopify 中指定的标准价格获得。如果购物车符合条件,只有一件礼品可以打折。