如何使用CakePHP和AJAX从表中的多个记录中删除单个记录

时间:2012-04-11 18:47:36

标签: jquery cakephp-2.0

我正在尝试构建一个系统,我可以使用AJAX将数据提交到数据库。我能做到这一点,而且效果很好。

然而,在尝试删除记录时,我很难做类似的事情。我是使用Ajax的新手,尤其是CakePHP,我发现整个概念非常庞大。我可以使用纯HTML删除记录,将ID传递给控制器​​,然后重定向到原始页面。这只是我正在努力的Ajax事情,显然使用Ajax将是一个巨大的好处。

这是我在我看来的代码:

    <table>
        <tr>
            <th>ID</th>
            <th>Title</th>
            <th>Content</th>
            <th>&nbsp;</th>
        </tr>
        <?php foreach ($testing as $test) { ?>
            <tr>
                <td><?php echo $test['Testtable']['id']; ?></td>
                <td><?php echo $test['Testtable']['title']; ?></td>
                <td><?php echo $test['Testtable']['content']; ?></td>
                <td><?php echo $this->Html->link('Delete', array('controller' => 'testing', 'action'=>'delete_ajax_data', $test['Testtable']['id']), null, 'Are you sure?' );?></td>
            </tr>
        <?php } ?>
    </table>

这是我控制器中的代码:

function delete_ajax_data($id) {
    $this->autoRender = false;
    $this->layout = 'ajax';

    $this->loadModel('Testtable');

    $this->Testtable->delete($id);
    $this->redirect('/test-area/');
}

这是我到目前为止我的Ajax代码:

$(document).ready(function(){

    $('a.confirm_delete').click(function(event){
        event.preventDefault();

        $.ajax({
            url:'/testing/delete_ajax_data',
            type:'POST',
            data: $("a").attr("href").serialize()

        });     
    });

});

为此提供任何帮助,它开始强调我了!

编辑: 我使用的代码错了,我现在已经包含了正确的代码。仍然没有工作!

1 个答案:

答案 0 :(得分:0)

我已经弄清楚了。我在代码中遇到了几个问题。

第一部分是在视图中。我没有使用CakePHP的链接构建器,而是使用了HTML链接:

<td><a href="id=<?php echo $test['Testtable']['id']; ?>" class="deleteajax">Delete</td>

然后,对于Ajax,我使用了以下代码:

$('a.deleteajax').click(function(event){
event.preventDefault();

var answer = confirm("Delete this record?")
if (answer){
    $.ajax({
        url:'/testing/delete_ajax_data/',
        type:'GET',
        data: $(this).attr("href")

    });
}

return false;  
});

新的Ajax代码使用GET而不是POST,它返回我正在删除的记录的ID作为ID变量,然后可以在控制器中使用,如下所示:

function delete_ajax_data() {
    $this->autoRender = false;
    $this->layout = 'ajax';

    $id = $_GET['id'];

    $this->loadModel('Testtable');

    $this->Testtable->delete($id);
}

可能有一种比我所做的更好的方法,但是对于我正在做的事情,这非常有效。