数据库问题很少

时间:2011-02-07 09:03:39

标签: jquery database codeigniter label

您正在进行座位预订项目。我在code_igniter中创建这个项目。现在我通过数据库发送座位标签有点问题。在我的项目中有一个小JQuery部分。当我选中一个复选框时,名称将被放置在标签上。但是当我将它发送到数据库时,它总是返回0 ???

这是我的jquery函数。

      $('[name=check]').each(function(i,d){
                    $(d).removeAttr('disabled');
                });
            }
                   $("#seatDiv").html($(this).val());
                 $(document).ready(function() {
                    $("input[name=check]").change(function() {
                    $("#seatDiv").html($(this).val());
                    })
                    });

我的表格

   echo form_open('user/register');
        $username = array(
           'name'       =>  'reg_username',
            'id'        =>  'reg_username',
            'value'     =>  set_value('reg_username')
        );
           $email = array(
           'name'       =>  'reg_email',
            'id'        =>  'reg_email',
            'value'     =>  set_value('reg_email')
        );
            $gsmnummer = array(
           'name'       =>  'reg_gsmnummer',
            'id'        =>  'reg_gsmnummer',
            'value'     =>  set_value('reg_gsmnummer')
        );
            $zitplaats = array(
           'name'       =>  'reg_zitplaats',
            'id'        =>  'reg_zitplaats',
            'value'     =>  '$id'
        );
    ?>
    <table>
        <tr>
            <td><label> Naam </label></td>
           <td> <div> <?php echo form_input($username); ?></div></td>
       </tr>
        <tr>
            <td><label>e-mail </label></td>
            <td><div> <?php echo form_input($email); ?></div></td>
        </tr>
        <tr>
            <td><label> gsm-nummer </label></td>
            <td><div> <?php echo form_input ($gsmnummer); ?> </div></td>
        </tr>
        <tr>
            <td><label>zitplaats</label></td>

            <td><div id="seatDiv" > <?php echo form_label($id='seatDiv'); ?> </div></td>
        </tr>
        <tr>
       <td> <?php echo form_submit(array('name'=> 'verzend','value' => 'verzend')); ?> </td>

      <?php echo form_close(); ?>

我的user_model

class User_model extends Model{
function User_model() {
    parent :: Model() ;
}
function register_user($username, $email, $gsmnummer, $zitplaats){

    $query_str ="INSERT INTO tbl_reservering (username,gsmnummer,email,zitplaats)VALUES(?, ?, ?, ?)";
    $this->db->query($query_str,array($username,$email,$gsmnummer,$zitplaats));
}

}

希望有人能帮助我!

谢谢你!

2 个答案:

答案 0 :(得分:0)

$zitplaats = array(
           'name'       =>  'reg_zitplaats',
            'id'        =>  'reg_zitplaats',
            'value'     =>  '$id'
        );

当变量用单引号时,不会解析变量。

以及$id的设置位置。

<tr>
            <td><label>zitplaats</label></td>

            <td><div id="seatDiv" > <?php echo form_label($id='seatDiv'); ?> </div></td>

您甚至没有在代码中使用$zitplaats

我不确定form_label($id='seatDiv')正在做什么,看起来不对我。

输出是什么?             

答案 1 :(得分:0)

您可以包含一个隐藏的输入,其中包含您要传递给控制器​​的值(最终是模型)。确保您的控制器已设置为检索“reg_zitplaats”。

你的jQuery看起来应该是这样的(我对你原来的帖子进行了一些修改,因为它做了一些非常奇怪的事情):

$(function() {
  $('input[name=check]').removeAttr('disabled'); // not sure why the checkbox is disabled to start off with

  $('input[name=check]').change(function() {
    $('#seatDiv').html($(this).val());
    $('#reg_zitplaats').val($(this).val());
  });
});

然后,您的html可以如此(注意隐藏的输入):

<?php 
echo form_open('user/register');
$username = array(
  'name' => 'reg_username',
  'id' =>  'reg_username',
  'value' =>  set_value('reg_username')
);

$email = array(
  'name' => 'reg_email',
  'id' => 'reg_email',
  'value' => set_value('reg_email')
);

$gsmnummer = array(
  'name' => 'reg_gsmnummer',
  'id' => 'reg_gsmnummer',
  'value' => set_value('reg_gsmnummer')
);

$zitplaats = array(
  'name' => 'reg_zitplaats',
  'id' => 'reg_zitplaats',
  'value' => $id
);
?>
<table>
  <tr>
    <td><label>Naam</label></td>
    <td>
      <div>
        <?php echo form_input($username); ?>
      </div>
    </td>
  </tr>
  <tr>
    <td><label>e-mail </label></td>
    <td>
      <div>
        <?php echo form_input($email); ?>
      </div>
    </td>
  </tr>
  <tr>
    <td><label>gsm-nummer</label></td>
    <td>
      <div>
        <?php echo form_input($gsmnummer); ?>
      </div>
    </td>
  </tr>
  <tr>
    <td><label>zitplaats</label></td>
    <td>
      <?php echo form_hidden($zitplaats); ?>
      <div id="seatDiv" > 
        <?php echo form_label($id='seatDiv'); ?>
      </div>
    </td>
  </tr>
  <tr>
    <td><?php echo form_submit(array('name'=> 'verzend','value' => 'verzend')); ?></td>
  </tr>
</table>
<?php echo form_close(); ?>

尝试一下,让我们知道你的去向。