【问题标题】:Remove lastIndexOf url with checkboxes使用复选框删除 lastIndexOf url
【发布时间】:2016-10-31 00:08:49
【问题描述】:

我正在尝试创建一个 2checkout 立即购买按钮。为了将正确的产品放入购物车,您需要将产品 ID 传递到 URL。我正在尝试根据用户选中和取消选中复选框的方式来构建 URL。

例如:

当用户选中复选框时,会使用&product_id= 将 URL 参数添加到基本 URL

$("#buynow").attr('href', function(){
    var baseURL = this.href;
    var newURL = baseURL + '&product_id=' + productID;
    return newURL;
})

用户取消选中该复选框,因此从 URL 中删除产品 ID:

$("#buynow").attr('href', function(){
    var oldURL = this.href;
    var newURL = oldURL.substr(oldURL.lastIndexOf('&'));
    return url.replace( new RegExp(oldURL), '' );
})

我遇到的问题是我有多个复选框可以添加和删除 URL。

典型场景:

用户选中复选框 A product_id=1,然后选中复选框 B product_id1=2

http://baseurl.com/sid=12345&product_id=1&product_id1=2

用户决定取消选中复选框 A。代码删除基于 '&' 的 lastIndexOf,然后删除复选框 B 产品 ID。

如何编写代码,使其不仅删除添加到 URL 的最后一个参数,而且根据产品 ID 知道要删除哪个产品。

希望这是有道理的。

【问题讨论】:

  • 我建议创建易于添加、更新或删除键和值的 JSON 对象,然后使用 for in 构建您的 url。

标签: javascript jquery checkbox attr 2checkout


【解决方案1】:

这是一个根据复选框的名称和值更新 href 的简单示例。

$(".url_p").change(function() {
  var href = "http://baseurl.com/";
  $(".url_p").each(function(i) {
    if (!$(this).is(":checked")) return;
    href += (href.indexOf("?")==-1 ? "?" : "&") + this.name + "=" + encodeURIComponent($(this).val());
  });
  console.log(href);
  $("#buynow").attr("href", href);
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type='checkbox' class='url_p' name='product_id' value='100'>Product id
<br/>

<input type='checkbox' class='url_p' name='price' value='80'>Price
<br/>

<input type='checkbox' class='url_p' name='amount' value='1'>Amount
<br/>

<a id='buynow' href='#'>Buy Now</a>

【讨论】:

  • 这正是我所需要的!谢谢好心的先生。
  • 很高兴能帮到你先生 :)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-04-18
  • 2014-02-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多