2014-02-08 99 views
0

如何将标记< a >的USER_ID传递给设置隐藏字段的Javascript函数Javascript?使用Javascript设置隐藏字段值

我试了Javascript函数showConfirm(),但隐藏的字段没有被填充。它保持为空......我认为字段deleteid的onClick属性写错了。

我想用javascript填充此字段。我怎么能够?

错误的消息称

您的SQL语法错误;检查手册中 对应于你的MySQL服务器版本正确的语法使用 “”附近的1号线

可能是因为隐藏字段"id_action"不接收功能的DATAS。

无论如何,主要的问题是设置功能showConfirm由参数'show', $row['id']隐藏字段id_action

  <script> 

      function showConfirm (action, delID) { 
       if (action == 'show') { 
       document.confirm.id_action.value = delID; 
       } 
      } 
      </script> 


      <tbody> 
       <?php 
        if (!empty($_POST)) { 
       if (isset($_POST['id_action'])) { 
       $del_id = $_POST['id_action']; 
        $delUser = new User; 
        $delUser->deletarUsuario($del_id); 
        unset($delUser); 
       } 
      } 
       $listUser = new User; 
       $result  = $listUser->listarUsers(); 
       if (is_array($result)) { 
        foreach ($result as $row) { 
        echo " 
        <tr> 
         <td align='right'>" . $row['id'] . "</td> 
          <td>". $row['name'] . " ".$row['sobrename']."</td> 
          <td>" . $row['email'] . "</td> 
          <td>" . $row['login'] . "</td> 
          <td> 
           <a data-toggle='modal' id='deleteid' data-target='#modal_delUser' onclick=\"showConfirm('show'," . $row['id'] . ")\"> 
           Remove 
           </a> 
          </td> 
        </tr>"; 
        } 
       } 
       unset($listUser); 
       ?> 
      </tbody> 


        <!-- Button trigger modal --> 
       <div class='modal fade' id='modal_delUser' tabindex='-1' role='dialog' aria-labelledby='modal_delUserLabel' aria-hidden='true'> 
       <div class='modal-dialog'> 
       <div class='modal-content panel-danger'> 
        <div class='modal-header panel-heading'> 
        <button type='button' class='close' data-dismiss='modal' aria-hidden='true'>&times;</button> 
        <h4 class='modal-title' id='modal_delUserLabel'>The user will be deleted</h4> 
        </div> 
        <div class='modal-body'> 
        Are you sure continue? 
        </div> 
        <div class="modal-footer"> 
        <form role="form" id="confirm" action="users.php" method="post"> 

         <input type="hidden" name="id_action"> 

         <button type="button" class="btn btn-default" data-dismiss="modal">No</button> 
         <button type="submit" class="btn btn-danger">Yes</button> 
        </form> 
        </div> 
       </div> 
       </div> 
      </div> 

这里,我从查询使用$id_action = $_POST["id_action"]

检查如果传递的ID在这个阶段产生

public function deletarUsuario($id) { 
    $del_id  = $this->db->real_escape_string(trim($id)); 
    if ($update = $this->db->query("DELETE FROM usuario WHERE id = $del_id")) { 
     if ($this->db->affected_rows) { 
      echo "<div><p>Deleted user!</p></div>"; 
     } 
     else { 
      echo "<div><p>Failed to delete user.</p></div>"; 
     } 

    } 
    else { 
     echo "<div><p>". $this->db->error."</p></div>"; 
       echo "<script>$('#modal_erroBD').modal('show');</script>"; 
    } 

} 

回答

0

做在PHP中的SQL:

变更

   if (isset($_POST['id_action'])) { 
       $del_id = $_POST['id_action']; 
        $delUser = new User; 
        $delUser->deletarUsuario($del_id); 
        unset($delUser); 
      } 

   if (isset($_POST['id_action'])) { 
       $del_id = $_POST['id_action']; 
        echo $del_id; 
      } 
+0

是的,我已经做了 – AlexDoria

+0

告诉我们,你是从查询产生,因为它不是在上面的代码中的SQL。 – malta

+0

对不起,我是新来的。有... – AlexDoria

相关问题