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

时间:2013-06-24 16:43:21

标签: javascript jquery attr

我正在为PHP中的URL缩短程序网站创建一个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或者可能使用不同的功能?

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

1 个答案:

答案 0 :(得分:0)

您必须使用onclick阻止默认event.preventDefault - 行为:

$("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']; ?>"});
});