gpt4 book ai didi

javascript - 没有为每个 session 值调用函数

转载 作者:可可西里 更新时间:2023-10-31 23:38:34 26 4
gpt4 key购买 nike

我正在开发一个游戏门户,教授应该可以在其中添加任何类型的问题。我在 form.php 中创建了问题类型(多项选择或描述性)函数,并将其包含在我的主文件中。首先在循环中我调用主框(简单的 html 框),我必须在其中添加问题。然后我提供了一个选项来选择问题类型来添加问题。在选择问题类型时,页面加载并提交表单,我正在获取该值并保存在动态创建的 session 变量中。一切正常,但主要问题是,当我选择问题类型时,它会为该特定框选择该类型,但所有其他问题都消失了。可能是它在 session 变量中的覆盖值。请指导我。

            <!-- BEGIN BORDERED TABLE PORTLET-->

<?
$q_no=5;
for ($i=0;$i<$q_no; $i++)
{
?>
<div class="portlet box yellow">
<div class="portlet-title">
<h4><i class="icon-coffee"></i>#<?echo $i+1;?> </h4>
<div class="tools">
<a href="javascript:;" class="collapse"></a>
<a href="#portlet-config" data-toggle="modal" class="config"></a>
<a href="javascript:;" class="reload"></a>
<a href="javascript:;" class="remove"></a>
</div>
</div>
<div class="portlet-body">
<table class="table table-bordered table-hover">
<thead>

</thead>
<tbody>
<form action="newGame.php" method="POST" id="input_type" name="input_type">
<div class="control-group">
<label class="control-label" > Add Input</label>
<div class="controls">
<select onchange="this.form.submit()" class="medium m-wrap" tabindex="1" id="type<?echo $i;?>" name="type<?echo $i;?>">
<option value="">Input Type</option>
<option value="1">Multiple Choice</option>
<option value="2">Input Field</option>
</select>
</div>
</div>
</form>

<?

//qType();


$_SESSION["input_type"][$i]= $_POST["type".$i];


if($_SESSION["input_type"][$i]==1)
{
form($q_no);
}
elseif($_SESSION["input_type"][$i]==2)
{

form1();
}

?>



</tbody>
</table>
</div>
</div>
<?
}

?>
<!-- END BORDERED TABLE PORTLET-->

这是我的 form.php 文件

    <?
function form()
{

?>

<form name="1" id="1" action="lecturer.php" method="POST">

<div class="control-group">

<div class="controls">
<textarea class="large m-wrap" placeholder=" Statement " cols="50"rows="3" name="statement<?echo $i;?>" style="text-align:center;" id="statement<?echo $i;?>"></textarea>
</div>
</div>
<div class="name">
<input name="option<?echo $i.'1';?>" id="option<?echo $i.'1';?>" placeholder="Option 1" style="width:170px;" type="text"/>

<input name="option<?echo $i.'2';?>" id="option<?echo $i.'2';?>" type="text" style="width:170px;" placeholder="Option 2"/>

<input name="option<?echo $i.'3';?>" id="option<?echo $i.'3';?>" type="text" style="width:170px;" placeholder="Option 3"/>

<input name="option<?echo $i.'4';?>" id="option<?echo $i.'4';?>" type="text" style="width:170px;" placeholder="Option 4"/>

</div>
<div class="control-group">

<div class="controls">
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'1';?>_default" />
Option 1
</label>
&nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'2';?>_default" checked />
Option 2
</label>
&nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'3'?>_default" />
Option 3
</label>
&nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'4';?>_default" />
Option 4
</label>
</div>
</div>
<p><input name="Submit" type="button" value="Submit" color="green" class="button" /></p>
</form>
<?php
}
//end
?>

<?php
function form1()
{ ?>

<div class="control-group" id ="field" name="field">
<label class="control- label">Answer</label>
<div class="controls">
<input type="text" placeholder="Answer" id ="ans" name="ans" class="m-wrap small" />
</div>
</div>
<?
}
?>

问题是我必须动态更改所有内容的 ID,因为我不知道问题的确切数量,用户应该能够添加他想要的任意数量的问题。

最佳答案

当您调用form() 函数时,您传递的是$q_no,但在声明时没有参数。先解决这个问题,然后告诉我。


您只接收当前选择的一个输出,但访问整个循环迭代。这是一个错误。

如果你想为单个问题添加多项选择/输入字段,那么你必须做两件事之一。

1) 为每个问题选择选项,并在单击任何按钮而不是选项更改时发送表单数据。

2) 使用 JavaScript 技巧解决问题。


我将在这里用 jQuery 给你一个例子。为此,您必须在 header 中导入 jquery

<!-- BEGIN BORDERED TABLE PORTLET-->



<?
$q_no=5;
for ($i=0;$i<$q_no; $i++)
{
?>
<div class="portlet box yellow">
<div class="portlet-title">
<h4><i class="icon-coffee"></i>#<?echo $i+1;?> </h4>
<div class="tools">
<a href="javascript:;" class="collapse"></a>
<a href="#portlet-config" data-toggle="modal" class="config"></a>
<a href="javascript:;" class="reload"></a>
<a href="javascript:;" class="remove"></a>
</div>
</div>
<div class="portlet-body">
<table class="table table-bordered table-hover">
<thead>

</thead>
<tbody>
<form action="newGame.php" method="POST" id="input_type" name="input_type">
<div class="control-group">
<label class="control-label" > Add Input</label>
<div class="controls">
<select onchange="this.form.submit()" class="medium m-wrap question_type" data-question-no="<?echo $i;?>" tabindex="1" id="type<?echo $i;?>" name="type<?echo $i;?>">
<option value="">Input Type</option>
<option value="1">Multiple Choice</option>
<option value="2">Input Field</option>
</select>
</div>
<div id="answer_no_<?php echo $i ?>"></div>
</div>
</form>

<?

//qType();

?>



</tbody>
</table>
</div>
</div>

//jQuery code with ajax in the same file

<script>
$(document).ready(function(){
$('.question_type').change(function(){
var question_no=$(this).attr('data-question-no');
$.ajax({
url: "provide_url",
type:'post',
data:{
type:$(this).val(),
i:question_no
},
success:function(data){
$('#answer_no_'+question_no).html(data);
}

});
});
});
</script>
<?
}

?>
<!-- END BORDERED TABLE PORTLET-->

表单.php 文件

<?
$i=$_post['i'];
$_SESSION["input_type"][$i]= $_POST["type"];


if($_SESSION["input_type"][$i]==1)
{
form();
}
elseif($_SESSION["input_type"][$i]==2)
{

form1();
}


function form()
{

?>

<form name="1" id="1" action="lecturer.php" method="POST">

<div class="control-group">

<div class="controls">
<textarea class="large m-wrap" placeholder=" Statement " cols="50"rows="3" name="statement<?echo $i;?>" style="text-align:center;" id="statement<?echo $i;?>"></textarea>
</div>
</div>
<div class="name">
<input name="option<?echo $i.'1';?>" id="option<?echo $i.'1';?>" placeholder="Option 1" style="width:170px;" type="text"/>

<input name="option<?echo $i.'2';?>" id="option<?echo $i.'2';?>" type="text" style="width:170px;" placeholder="Option 2"/>

<input name="option<?echo $i.'3';?>" id="option<?echo $i.'3';?>" type="text" style="width:170px;" placeholder="Option 3"/>

<input name="option<?echo $i.'4';?>" id="option<?echo $i.'4';?>" type="text" style="width:170px;" placeholder="Option 4"/>

</div>
<div class="control-group">

<div class="controls">
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'1';?>_default" />
Option 1
</label>
&nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'2';?>_default" checked />
Option 2
</label>
&nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'3'?>_default" />
Option 3
</label>
&nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp &nbsp
<label class="radio">
<input type="radio" name="option1_default" id="option<?echo $i.'4';?>_default" />
Option 4
</label>
</div>
</div>
<p><input name="Submit" type="button" value="Submit" color="green" class="button" /></p>
</form>
<?php
}
//end
?>

<?php
function form1()
{ ?>

<div class="control-group" id ="field" name="field">
<label class="control- label">Answer</label>
<div class="controls">
<input type="text" placeholder="Answer" id ="ans" name="ans" class="m-wrap small" />
</div>
</div>
<?
}
?>

关于javascript - 没有为每个 session 值调用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33904923/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com