我想要实现的是删除整行。首先我显示表格,然后如果你点击每行的“删除”按钮,则会出现一个确认模式,询问你是否要删除该行。
我正在尝试使用jquery,ajax,json和PHP。我当然还在学习。
到目前为止,我所拥有的是:
Javascript文件:
function callToModal(data){
$('#myModal3 .modal-body p').html("Desea eliminar al usuario " + '<b>' + data + '</b>' + ' ?');
$('#myModal3').modal('show');
$('.confirm-delete').on('click', function(e) {
e.preventDefault();
var id = $(this).data('id');
$('#myModal3').data('id', id).modal('show');
});
$('#btnYes').click(function() {
// handle deletion here
var id = $('#myModal3').data('id');
alert(id);
$.ajax({
url: "deleteFrontUser",
type: 'POST',
data: {
id:id
},
success: function(html){
//alert(html);
$('[data-id='+id+']').parents('tr').remove();
$('#myModal3').modal('hide');
}
});
return false;
});
};
在我的admin.php文件中:
public function deleteFrontUser(){
// var_dump($_POST['id']);die();
$rowId = $_POST['rowId'];
$result = array();
$front = UserDs::getInstance()->getUserById($id);
UserDs::getInstance()->deleteItem($front);
$result["message"] = "Usuario eliminado";
echo json_encode($result);
}
视图(请注意我正在使用Smarty模板引擎):
<div class="portlet-body">
<table class="table table-striped table-hover table-users">
<thead>
<tr>
<th>Avatar</th>
<th class="hidden-phone">Usuario</th>
<th>Nombre</th>
<th>Apellido</th>
<th class="hidden-phone">Email</th>
<th class="hidden-phone">Provincia</th>
<th class="hidden-phone">Miembro desde</th>
<th>Estado</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
{foreach $frontusers as $frontuser}
<tr>
{if $frontuser->frontavatar_id eq null}
<td><img src="{site_url()}assets/img/avatar.png" alt="" /></td>
{else}
<td><img src="{site_url()}assets/img/avatar1.jpg" alt="" /></td>
{/if}
<td class="hidden-phone">{$frontuser->username}</td>
<td>{$frontuser->name}</td>
<td>{$frontuser->lastname}</td>
<td class="hidden-phone">{$frontuser->email}</td>
<td class="hidden-phone">{$frontuser->state}</td>
<td class="hidden-phone">{$frontuser->creation_date|date_format:"%Y/%m/%d"}</td>
{if $frontuser->status eq 2}
<td ><span class="label label-success">Activo</span></td>
{else}
<td ><span class="label label-warning">No Activo</span></td>
{/if}
<td><a class="btn mini blue-stripe" href="{site_url()}admin/editFront/{$frontuser->id}">Modificar</a></td>
<td><a href="#" class="btn mini red-stripe confirm-delete" role="button" onclick="callToModal('{$frontuser->username}');" data-id="{$frontuser->id}">Eliminar</a></td>
</tr>
<!-- modal -->
<div id="myModal3" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel3" aria-hidden="true">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true"></button>
<h3 id="myModalLabel3">Eliminar</h3>
</div>
<div class="modal-body">
<p></p>
</div>
<div class="modal-footer">
<button class="btn" data-dismiss="modal" aria-hidden="true">Cerrar</button>
<button data-dismiss="modal" class="btn red" id="btnYes">Confirmar</button>
</div>
</div>
<!-- end modal -->
{foreachelse}
<tr>
<td colspan="2"><span class="text-error"><i class="icon-exclamation"></i> No hay Usuarios cargados.</span></td>
</tr>
{/foreach}
</tbody>
</table>
</div>
当您单击特定行的删除按钮时会显示模式,但这是有趣的事情:第一次按删除时,它不会删除该行。当您按下该行或任何其他行时(按一次删除后),该行将被删除。所以这是一个问题,另一个问题是我无法管理将数据发送到我的php文件,所以我可以从数据库中删除它。
我该如何解决这个问题?
如果你想查看:code
,我有一个定制的小提琴答案 0 :(得分:1)
url
必须是位于您网站内的有效网站,您不能在url
内拥有功能名称,因为AJAX调用无法知道该功能位于哪个文件中。
所以你的url
必须是:
url: "admin.php"
但是,您可以在AJAX
调用中添加另一个参数来告诉admin.php
它应该执行哪个函数,这样就可以了:
$.ajax({
url: "admin.php",
type: 'POST',
data: {
id:id,
func:"deleteFrontUser"
},
success: function(html)
{
//alert(html);
$('[data-id='+id+']').parents('tr').remove();
$('#myModal3').modal('hide');
}
});
因此,在admin.php
之前,您必须在输入函数之前收到已发布的数据,并且您可以解析func变量以告知要执行的函数:
$rowId = $_POST['id'];
$func = $_POST['func'];
switch ($func)
{
case 'deleteFrontUser':
deleteFrontUser($rowId);
break;
default:
// function not found.
break;
}
deleteFrontUser
看起来像这样:
public function deleteFrontUser($rowId)
{
$result = array();
// Rest of the code.
echo json_encode($result);
}
也许你需要稍微修改一下,但这应该会给你一个想法。
有关详细信息,请查看$.ajax documentation。
注意:强>
为了获得最佳实践的原因,请使用php's isset函数来确定数据是否实际发布。 ternary运算符使这非常容易和简短:
$emptyString = "";
$rowId = isset($_POST['id']) ? $_POST['id'] : $emptyString;
$func = isset($_POST['func']) ? $_POST['func'] : $emptyString;
我还建议使用jQuery的.on函数,让它采用参数“click”,其功能将在click事件中触发。 .click
通常是不好的做法,因为它无法检测到DOM树中的更改,因此当您使用新的HTML更新它时,.on
允许您向dom树添加新元素但仍然能够听取与他们相对应的事件。
答案 1 :(得分:0)
解决方案是:
请参阅我之前的帖子,以获得正确的js文件并查看:post
从数据库中删除整行的Php代码为:
public function deleteFrontUser(){
$rowId = $_POST['id'];
$result = array();
$front = UserDs::getInstance()->getUserById($rowId);
UserDs::getInstance()->deleteItem($front);
$result["message"] = "Usuario eliminado";
echo json_encode($result);
}