javascript - 如何获得动态创建的 ID?

标签 javascript php jquery html ajax

我是使用 javascript 和 ajax 的绝对初学者,这就是我现在被困的原因。我有一个 while 循环,其中有 2 个不同的按钮。正如我想象的那样,两者都有效,除了一件小事......

product-id 总是只为第一个元素传递,或者,如果我为最后一个元素更改它。 如何将正确的产品 ID 传递给脚本?

这是我的 PHP 文件:

<?php while ( $product = $browse->fetch( PDO::FETCH_ASSOC ) ) :
    $postid = $product[ 'id' ];
    $userid = 1; ?>

 <div id="content_<?php echo $postid ?>">
 <div id="reload_<?php echo $postid ?>" class="row postfarbe browse">

  <form method='post' action="" onsubmit="return add();">
    <input type="hidden" id="userid" value="<?php echo $userid ?>" class="input-box">
    <input type="hidden" id="productid" value="<?php echo $postid ?>" class="input-box">
    <input type="hidden" id="collection" value="1" class="input-box">
    <input type="hidden" id="wish" value="0" class="input-box">
    <input type="submit" id="submit" value="Add to Collection" class="btn my-2 my-sm-0 btn-outline-dark btn-sm">
  </form>

 </div>
</div>
<?php endwhile; ?>

我的 Javascript 是:

function add()
{
    var userid = document.getElementById("userid").value;
    var productid = document.getElementById("productid").value;
    var collection = document.getElementById("collection").value;
    var wishlist = document.getElementById("wish").value;
    if(userid && productid && collection && wishlist) {
        $.ajax
        ({
            type: 'post',
            url: 'post_collection.php',
            data: {
                user_id:userid,
                product_id:productid,
                collection_id:collection,
                wishlist_id:wishlist
            },
            success: function (response) {
                $("#content_"+ productid).load(" #reload_" + productid);
            }
        });
    }  
    return false;
}
</script>

我知道示例中的产品 ID 始终相同,但如果循环中有 10 个或更多条目,我如何才能将正确的 ID 传递给脚本?

最佳答案

你的问题id是唯一的,只能分配给一个元素一次,如下所示:

<p id="paragraph"> This is legal </p>
<p id="paragraph"> This is illegal - It is no longer unique </p>

<p class="paragraph"> This is legal </p>
<p class="paragraph"> This is legal </p>

您可以使用$(this) 访问当前点击的类像这样:

$('.paragraph').click(function() {
    $(this).html('See, totally legal.');
});

See this example看看它的使用情况。


您的解决方案需要添加一个 onclick() button 的方法.然后得到 parent() 形式。然后你可以 find() 类(class)并获得 val() 来自表单数据。

您的表单也在提交操作。你需要有一个 <button>类型 button所以它不提交 Action 。这也必须是一个类,因为如果您多次创建它们,它将不是唯一的。

这是一个工作示例,也可以重新添加您的 AJAX 请求。

$(document).ready(function() {
  $('.submit-btn').click(function() {
    var elements = {
      'userid': $(this).parent().find('.userid').val(),
      'productid': $(this).parent().find('.productid').val(),
      'collection': $(this).parent().find('.collection').val(),
      'wish': $(this).parent().find('.wish').val()
    };

    console.log("User ID: " + elements.userid);
    console.log("Product ID: " + elements.productid);
    console.log("Collection: " + elements.collection);
    console.log("Wish: " + elements.wish);

    // TODO: Add your AJAX request using these elements
  });
});
button {
  background: #0084ff;
  border: none;
  border-radius: 5px;
  padding: 8px 14px;
  font-size: 15px;
  color: #fff;
  cursor: pointer;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<!-- This will be generated by PHP -->

<form method='POST'>
  <input hidden class="userid input-box" value="1">
  <input hidden class="productid input-box" value="1">
  <input hidden class="collection input-box" value="1">
  <input hidden class="wish input-box" value="1">
  <button type="button" class="submit-btn btn my-2 my-sm-0 btn-outline-dark btn-sm"> Add to collection </button>
</form>

<!-- This will be generated by PHP -->
<br />

<form method='POST'>
  <input hidden class="userid input-box" value="2">
  <input hidden class="productid input-box" value="2">
  <input hidden class="collection input-box" value="2">
  <input hidden class="wish input-box" value="2">
  <button type="button" class="submit-btn btn my-2 my-sm-0 btn-outline-dark btn-sm"> Add to collection </button>
</form>


您的 AJAX 数据将如下所示:

data: {
    user_id: elements.userid,
    product_id: elements.productid,
    collection_id: elements.collection,
    wishlist_id: elements.wish
}

您的 PHP 代码可能如下所示:

<?php foreach($browse->fetchAll(PDO::FETCH_ASSOC) as $product):
    $id = $product['id'];
    $productDd = $product['product_id'];
    $productCategory = $product['category']; // TODO: change to your column nanme
    $productWishList = $product['wish']; ?>

    <div class="content_<?= $id; ?>">
        <div class="reload_<?= $id; ?> row postfarbe browse">
            <form method='POST'>
                <input hidden class="userid input-box" value="<?= $id; ?>">
                <input hidden class="productid input-box" value="<?= $productCategory; ?>">
                <input hidden class="collection input-box" value="<?= $productCollection; ?>">
                <input hidden class="wish input-box" value="<?= $productWishList; ?>">
                <button type="button" class="submit-btn btn my-2 my-sm-0 btn-outline-dark btn-sm"> Add to collection </button>
            </form>
        </div>
    </div>

<?php endforeach; ?>

关于javascript - 如何获得动态创建的 ID?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52806405/

相关文章:

javascript - 如何将参数传递给 addEventListener 监听器函数?

javascript - 用 jQuery 清空 div 然后把它放回去?

javascript - 使 slider 气泡跟上左 handle

jquery可调整大小附加图像大小问题

javascript - 使用 jQuery 捕获 iframe 重新加载

php - 有没有办法在 zend 导航中有一个没有链接的导航条目?

php - 在 php 和 MySQL 中匹配和返回行

php - SQL Plus 和 "regular"SQL 的区别?

javascript - 使用 Javascript 获取上传的文件内容

javascript - 为什么 preventDefault on checkbox click 事件为 checked 属性返回 true?