我正在尝试构建一个系统,我可以使用AJAX将数据提交到数据库。我能做到这一点,而且效果很好。
然而,在尝试删除记录时,我很难做类似的事情。我是使用Ajax的新手,尤其是CakePHP,我发现整个概念非常庞大。我可以使用纯HTML删除记录,将ID传递给控制器,然后重定向到原始页面。这只是我正在努力的Ajax事情,显然使用Ajax将是一个巨大的好处。
这是我在我看来的代码:
<table>
<tr>
<th>ID</th>
<th>Title</th>
<th>Content</th>
<th> </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()
});
});
});
为此提供任何帮助,它开始强调我了!
编辑: 我使用的代码错了,我现在已经包含了正确的代码。仍然没有工作!
答案 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);
}
可能有一种比我所做的更好的方法,但是对于我正在做的事情,这非常有效。