jQuery,从列表中间删除项目,然后刷新列表?

时间:2009-11-28 06:46:21

标签: jquery list refresh

我有一个由包含的PHP文件加载的ul列表。这些项目有一个“删除”链接,可以将它们从列表和数据库中删除。

使用以下代码从列表中心删除项目时:

$list.find('#city_' + $id).remove();

它在列表中留下了这样的空格:

alt text http://www.jamespwright.com/images/public/screengrabs/2e6216c93997b6bc9d4e07657851572f.PNG

我可以做些什么来刷新该列表,而无需返回数据库并重新加载整个数据库?

修改

以下是示例代码:

<ul id="city_list">
    <li id='city_7'>Eureka - <a href='city.modify.php?id=7&modification_type=edit'>Edit</a> - <a href='#' delete_id='7' class='confirm_delete'>Delete</a></li> <br />
    <li id='city_8'>Rolla - <a href='city.modify.php?id=8&modification_type=edit'>Edit</a> - <a href='#' delete_id='8' class='confirm_delete'>Delete</a></li> <br />

    <li id='city_10'>Union - <a href='city.modify.php?id=10&modification_type=edit'>Edit</a> - <a href='#' delete_id='10' class='confirm_delete'>Delete</a></li> <br />

6 个答案:

答案 0 :(得分:3)

我猜你的HTML看起来像这样:

<li><div id="city01">Eureka - <a...>Edit</a> - <a...>Delete</a></div></li>

在这种情况下,您需要删除选择器的父级

$list.find('#city_' + $id).parent().remove();

答案 1 :(得分:2)

id="city_X"<li><label>上重复。 id在文档中必须是唯一的,否则在尝试$('#my_id')时会有未定义的行为。

<label>用于表单输入元素,不用于文本显示。使用无标记或<span>

我将如何做到这一点:

<ul id="city_list">
    <li id='city_7' class="city">
        <span class="label">Eureka</span>
         - <a href='city.modify.php?id=7&modification_type=edit'>Edit</a>
         - <a href='#' class='confirm_delete'>Delete</a>
    </li> 
    <li id='city_8' class="city">
        <span class="label">Rolla</span>
         - <a href='city.modify.php?id=8&modification_type=edit'>Edit</a>
         - <a href='#' class='confirm_delete'>Delete</a>
    </li>        
    <li id='city_10' class="city">
        <span class="label">Union</span>
         - <a href='city.modify.php?id=10&modification_type=edit'>Edit</a>
         - <a href='#' class='confirm_delete'>Delete</a>
    </li> 
</ul>

假设您想在点击删除链接时删除。

// Use event delegation
$('#city_list').bind('click', function(event)
{
    $(event.target).closest('.confirm_delete').each(function()
    {
        // Get ID from city
        var $city = $(this).closest('.city');
        var id = $city.attr('id').match(/city_(.+)/)[1];

        // Do any AJAX request to tell the server to delete the city

        $city.remove();
    })
})

答案 2 :(得分:1)

你可以试试这个

$list.find('#city_' + $id).hide('fast', function() {
     $(this).remove();
}); 

答案 3 :(得分:1)

$id包含一个简单的值,而不是包装集? ..好吧......好吧......

这样做

$('#city_' + $id).parent().remove();

$('div:has(#city_' + $id + ')').remove();

如果您的html正确形成w / unique ids,则无需使用$list$().find()

答案 4 :(得分:1)

您可以使用FireBug来查看实际删除的内容,但我猜它是标签元素,而不是li元素。你设计它的方式使它看起来好像是一个空的空间,而我认为这是一个空的列表元素。

这个怎么样:

$list.find('li#city_' + $id).remove();

答案 5 :(得分:1)

$list.find('#city_' + $id).next().remove() /* remove the <br/> */
     .end() /* go back to what was found originally */
     .remove(); /* and remove */