jQuery通过attr更改ID,然后调用它

jQuery changing ID via attr and then calling it

本文关键字:然后 调用 ID 通过 attr 更改 jQuery      更新时间:2023-09-26

我正在用PHP为我的URL shortener网站创建一个UserCP,但我已经停止了,因为我现在遇到了一个无法解决的小问题。

我想让用户通过使用Javascript的库Jquery轻松地更新URL。到目前为止,如果你点击"编辑"按钮(见下文),文本就会变成文本字段,所以它是可编辑的!这太棒了。在将其制作成文本字段的过程中,我使用了attr()函数来更改将文本制作成文本域的按钮的类名和ID。使用我分配的新ID将向PHP脚本发送$.POST。我希望你能理解,我会把下面的代码展示给你看!

<?php while($list = $listURLs->fetch_array()) { ?>
<td id="longURL<?= $list['ID']; ?>"><a rel="tooltip" title="<?= $list['longURL']; ?>" target="_blank" href="<?= $list['longURL']; ?>"><?= substr($list['longURL'],0,25); ?></a></td>
        <td id="shortURL<?= $list['ID']; ?>"><input type='text' class='span2' onmouseover="(this.select())" value='http://smurl.es/<?= $list['shortURL']; ?>'/></td>
        <td><?= $list['type']; ?></td>
        <td><?= $time; ?></td>
        <td><?= $list['hits']; ?></td>
        <td><button id="edit<?= $list['ID']; ?>" class='btn btn-warning btn-small' rel='tooltip' title='Edit'><i class="icon icon-edit"></i></button>&nbsp;<button id="del<?= $list['ID']; ?>" class='btn btn-danger btn-small' rel='tooltip' title='Delete'><i class="icon icon-trash"></i></button></td>
    </tr>
        <script type="text/javascript">
            $("button#edit<?= $list['ID']; ?>").click(function() {
            $('#longURL<?= $list['ID']; ?>').html("<input type='text' value='<?= $list['longURL']; ?>' />");
            $('#shortURL<?= $list['ID']; ?>').html("<div class='input-prepend'><span class='add-on'>http://smurl.es/</span><input id='prependedInput' type='text' value='<?= $list['shortURL']; ?>' class='span1' /></div>");
            $("button#edit<?= $list['ID']; ?>").attr({"class": "btn btn-info btn-small test", "data-original-title": "Click to Save", "id": "save<?= $list['ID']; ?>"});
            });

            $('button#save<?= $list['ID']; ?>').click(function() {
                             alert("testing - DEBUG"); // Save code here
            });
        </script>
    <?php 
        }
    }
     ?>

所以,如果你仍然有点困惑,我只想知道我如何调用我通过attr或其他函数创建的ID?

我已经检查了我的控制台,没有发现任何错误。

您必须使用event.preventDefault:来防止默认的onclick行为

$("button#edit<?= $list['ID']; ?>").click(function(e) {
    e.preventDefault();
    $('#longURL<?= $list['ID']; ?>').html("<input type='text' value='<?= $list['longURL']; ?>' />");
    $('#shortURL<?= $list['ID']; ?>').html("<div class='input-prepend'><span class='add-on'>http://smurl.es/</span><input id='prependedInput' type='text' value='<?= $list['shortURL']; ?>' class='span1' /></div>");
    $("button#edit<?= $list['ID']; ?>").attr({"class": "btn btn-info btn-small test", "data-original-title": "Click to Save", "id": "save<?= $list['ID']; ?>"});
});