AJAX代码用于插入,更新和删除数据库项

时间:2013-07-10 10:19:12

标签: javascript jquery ajax symfony doctrine-orm

我有这个dropdwonlist,这个数字是投票,我的猜测很简单:如何通过按“ - ”删除数据库的投票来做到这一点,当我按任何其他数字时,投票将在数据库中更新有这个价值吗?

下拉列表的默认值为votacion.votCalificacion,这是数据库中投票的值

这是投票的下拉列表:

<form id="post">
    <select id="cd-dropdown" class="cd-select">
        <option value="-1" selected>{{ voto.votCalificacion }}</option>
        <option>-</option>
        <option>1</option>
        <option>2</option>
        <option>3</option>
        <option>4</option>
        <option>5</option>
        <option>6</option>
        <option>7</option>
        <option>8</option>
        <option>9</option>
        <option>10</option>
    </select>
</form>

这是管理员管理投票的功能:

public function gestionarVotoAction($pysStr, $votCalificacion)
{
    $em = $this->getDoctrine()->getManager();
    $pys = $em->getRepository('PYSBundle:Pys')->findPys($pysStr);
    $usuario = $this->get('security.context')->getToken()->getUser();

    $voto = $em->getRepository('UsuarioBundle:Usuario')->findVoto($usuario, $pys);

    if(!$voto) 
    {
        $voto = new Voto($usuario, $pys);
    }

    if ($votCalificacion == "-") 
    {
        $em->remove($voto);
    }
    else
    {
        $voto->setVotCalificacion($votCalificacion);
        $voto->setVotFecha(new \DateTime("now"));

        $em->persist($voto); 
    }

    $em->flush();
    return $this->redirect($this->generateUrl('usuario_pelicula', array('pysStr' => $pysStr)));
}

2 个答案:

答案 0 :(得分:1)

您可以在此举例:

A voting system with jQuery, PHP and Smarty

而且,为了正确管理jQuery,这里有一些你可能知道的函数:

AJAX请愿书的

jQuery.ajax() http://api.jquery.com/jQuery.ajax/

用于AJAX请求的

jQuery.load()会导致页面中某处出现新的已加载内容 http://api.jquery.com/load/

修改 经过几次聊天,这里就是答案:

$('#cd-dropdown').bind("change", function(){ 
  ajaxVotar($('#cd-dropdown').val(), $('#id-pelicula').val()); 
}); 


function ajaxVotar(voto, pelicula) 
{ 
  $.getJSON('/app_dev.php/es/user/pelicula/'+pelicula+'/'+voto, function(j){ 
    alert(j.result); 
    $('#votacion-media-peli').html(j.media); 
    // Customize whatever you want...
  }); 
}

此处的整个聊天会话:http://chat.stackoverflow.com/rooms/33245/discussion-between-dani-sancas-and-benatespina

答案 1 :(得分:0)

first assign object

if(new add)
{
$oArticle  =new article() 
}
else
{
$oArticle  =$this->getDoctrine()->getRepository('ArticleBundle:Article')->Find($id);
}
$oArticle->setField($field);
$em = $this->get('doctrine')->getEntityManager();
$em->persist($oArticle);
$em->flush();