您正在进行座位预订项目。我在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));
}
}
希望有人能帮助我!
谢谢你!答案 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(); ?>
尝试一下,让我们知道你的去向。