Krijg antwoord laatste vraag niet uitgelezen (quiz PHP)
Ik krijg het antwoord van de laatste vraag niet uitgelezen waardoor die automatisch goed word gerekend.
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
<?php
// Start the session
session_start();
if(isset($_SESSION['aantalvragen']))
{
$aantalvragen = $_SESSION['aantalvragen'];
$cijfer = $_SESSION['cijfer'];
$goed = $_SESSION['goed'];
$fout = $_SESSION['fout'];
$antwoord = $_SESSION['antwoord'];
}
else
{
$aantalvragen = 0;
$cijfer = 0;
$goed = 0;
$fout = 0;
}
if(isset($_SESSION["sommen"]))
{
$sommen = $_SESSION["sommen"];
}
else
{
$sommen = array();
}
if (isset($_GET['answer']))
{
$antwoordgebruiker = $_GET['answer'];
}
else
{
$antwoordgebruiker = NULL;
}
//var_dump($sommen); uitlezen array
$w = 1;
$res = false;
if($aantalvragen<=4) //kleiner of gelijk aan 20
{
$nummer = $aantalvragen - 1;
$nummer1 = $aantalvragen + 1;
$antwoordquery = mysql_query("SELECT * FROM vragen WHERE ID = '".$aantalvragen."'");
$vraagdata = mysql_fetch_assoc($antwoordquery);
$antwoordquery1 = mysql_query("SELECT * FROM vragen WHERE ID = '".$nummer."'");
$vraagdata1 = mysql_fetch_assoc($antwoordquery1);
$vraag = $vraagdata['vraag'];
$antwoord = $vraagdata1['goede-antwoord'];
if($antwoord == $antwoordgebruiker) //als het antwoord gelijk is
{
$goed = $goed + 1;
$cijfer = $cijfer + 0.5;
}
else
{
$fout = $fout + 1;
}
$w = $w + 1;
echo $antwoordgebruiker.' - '.$antwoord;
echo'<div id="pagina">';
echo '<div id="som">';
echo '<form method="POST" >';
echo '<b><h2>Vraag '.$nummer1.' / 20</h2></b>';
echo '<h1>'.$vraag.'</h1>';
echo '<table border="1" style="width: 40%;"><tr class="somans">';
echo '<td style="width: 10%; background-color: orange;" > A:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=A"> '.$vraagdata['antwoord1'].'</td></tr></a>';
echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> B:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=B"> '.$vraagdata['antwoord2'].'</td></tr></a>';
echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> C:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=C"> '.$vraagdata['antwoord3'].'</td></tr></a>';
echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> D:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=D"> '.$vraagdata['antwoord4'].'</td></tr></a>';
echo "</tr>";
echo '</form>';
echo '</div>';
$aantalvragen++; // telt de vragen op
$_SESSION['antwoordgebruiker'] = $antwoordgebruiker;
$_SESSION['antwoord'] = $antwoord;
$_SESSION['aantalvragen'] = $aantalvragen;
$_SESSION['goed'] = $goed;
$_SESSION['fout'] = $fout;
$_SESSION['cijfer'] = $cijfer;
$_SESSION["sommen"] = $sommen;
}
else
{
$sommen = $_SESSION["sommen"]; // uitslag
echo'<div id="pagina">';
echo '<div id="res">';
if($cijfer<5.5)
{
echo '<h1> Cijfer: </h1> <h1 id ="red"> '.$cijfer.'</h1>';
}
else
{
echo '<h1> Cijfer: </h1> <h1 id ="green"> '.$cijfer.'</h1>';
}
echo '<h2 id="green">Goed: '.$goed.'</h2>';
echo '<h2 id="red">Fout: '.$fout.'</h2><br/><br/>';
echo '<a href="index.php"><input type="submit" value="Terug naar Home"></a>';
echo '</div>';
echo '</div>';
session_destroy();
// verwijderd de sessie zodat de sommen weer opnieuw gemaakt kunnen worden
}
?>
</body>
</html>
// Start the session
session_start();
if(isset($_SESSION['aantalvragen']))
{
$aantalvragen = $_SESSION['aantalvragen'];
$cijfer = $_SESSION['cijfer'];
$goed = $_SESSION['goed'];
$fout = $_SESSION['fout'];
$antwoord = $_SESSION['antwoord'];
}
else
{
$aantalvragen = 0;
$cijfer = 0;
$goed = 0;
$fout = 0;
}
if(isset($_SESSION["sommen"]))
{
$sommen = $_SESSION["sommen"];
}
else
{
$sommen = array();
}
if (isset($_GET['answer']))
{
$antwoordgebruiker = $_GET['answer'];
}
else
{
$antwoordgebruiker = NULL;
}
//var_dump($sommen); uitlezen array
$w = 1;
$res = false;
if($aantalvragen<=4) //kleiner of gelijk aan 20
{
$nummer = $aantalvragen - 1;
$nummer1 = $aantalvragen + 1;
$antwoordquery = mysql_query("SELECT * FROM vragen WHERE ID = '".$aantalvragen."'");
$vraagdata = mysql_fetch_assoc($antwoordquery);
$antwoordquery1 = mysql_query("SELECT * FROM vragen WHERE ID = '".$nummer."'");
$vraagdata1 = mysql_fetch_assoc($antwoordquery1);
$vraag = $vraagdata['vraag'];
$antwoord = $vraagdata1['goede-antwoord'];
if($antwoord == $antwoordgebruiker) //als het antwoord gelijk is
{
$goed = $goed + 1;
$cijfer = $cijfer + 0.5;
}
else
{
$fout = $fout + 1;
}
$w = $w + 1;
echo $antwoordgebruiker.' - '.$antwoord;
echo'<div id="pagina">';
echo '<div id="som">';
echo '<form method="POST" >';
echo '<b><h2>Vraag '.$nummer1.' / 20</h2></b>';
echo '<h1>'.$vraag.'</h1>';
echo '<table border="1" style="width: 40%;"><tr class="somans">';
echo '<td style="width: 10%; background-color: orange;" > A:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=A"> '.$vraagdata['antwoord1'].'</td></tr></a>';
echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> B:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=B"> '.$vraagdata['antwoord2'].'</td></tr></a>';
echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> C:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=C"> '.$vraagdata['antwoord3'].'</td></tr></a>';
echo '<tr class="somans"><td style="width: 10%; background-color: orange;"> D:</td><td style="background-color: lightblue;"><a href="index.php?paginaNR=4&ID='.$aantalvragen.'&answer=D"> '.$vraagdata['antwoord4'].'</td></tr></a>';
echo "</tr>";
echo '</form>';
echo '</div>';
$aantalvragen++; // telt de vragen op
$_SESSION['antwoordgebruiker'] = $antwoordgebruiker;
$_SESSION['antwoord'] = $antwoord;
$_SESSION['aantalvragen'] = $aantalvragen;
$_SESSION['goed'] = $goed;
$_SESSION['fout'] = $fout;
$_SESSION['cijfer'] = $cijfer;
$_SESSION["sommen"] = $sommen;
}
else
{
$sommen = $_SESSION["sommen"]; // uitslag
echo'<div id="pagina">';
echo '<div id="res">';
if($cijfer<5.5)
{
echo '<h1> Cijfer: </h1> <h1 id ="red"> '.$cijfer.'</h1>';
}
else
{
echo '<h1> Cijfer: </h1> <h1 id ="green"> '.$cijfer.'</h1>';
}
echo '<h2 id="green">Goed: '.$goed.'</h2>';
echo '<h2 id="red">Fout: '.$fout.'</h2><br/><br/>';
echo '<a href="index.php"><input type="submit" value="Terug naar Home"></a>';
echo '</div>';
echo '</div>';
session_destroy();
// verwijderd de sessie zodat de sommen weer opnieuw gemaakt kunnen worden
}
?>
</body>
</html>
Ik mis het volgende puzzelstukje: de data in de tabel "vragen".
Verder zou ik bovenstaande code wat verder uit elkaar trekken. Het onderscheid tussen het weergeven van een vraag en de verwerking ervan (en eventueel de functionaliteit voor paginering) zou je groter kunnen maken, zodat je deze ook (meer) in afzondering kunt behandelen.
Verder zou ik bovenstaande code wat verder uit elkaar trekken. Het onderscheid tussen het weergeven van een vraag en de verwerking ervan (en eventueel de functionaliteit voor paginering) zou je groter kunnen maken, zodat je deze ook (meer) in afzondering kunt behandelen.
de data in de tabel "vragen" is gewoon gevuld met 3 vragen
de kolomnamen zijn:
ID
vraag
antwoord1
antwoord2
antwoord3
antwoord4
goede-antwoord
de kolomnamen zijn:
ID
vraag
antwoord1
antwoord2
antwoord3
antwoord4
goede-antwoord
En wat als je nou opeens 5 vragen hebt? In ieder geval is de databaseopzet dus niet correct.
Tevens wou ik graag even opmerken dat de mysql_*() functies over een ruim jaar echt ter ziele zullen gaan als menig hosting over zal stappen op PHP7.
Tevens wou ik graag even opmerken dat de mysql_*() functies over een ruim jaar echt ter ziele zullen gaan als menig hosting over zal stappen op PHP7.
ja dat snap ik
maar ik gebruik voor nu even mysql_*() functies
ik maak een quiz dus ik maak het aantal vragen handmatig.
ik krijg alle antwoorden goed uitgelezen behalve de laatste
maar ik gebruik voor nu even mysql_*() functies
ik maak een quiz dus ik maak het aantal vragen handmatig.
ik krijg alle antwoorden goed uitgelezen behalve de laatste
Ik heb geen idee wat er allemaal gebeurt maar wat mij in ieder geval vreemd overkomt is het volgende: het formulier heeft hardcoded hyperlinks, die alle verwijzen naar ?paginaNR=4. Dit lijkt mij de verkeerde insteek. Hiermee omzeil je ook de normale werking van het formulier, die hyperlinks maken in feite het formulier overbodig. Kies voor een van de twee (waarbij ik zou gaan voor een formulier).
Ik hoop ook dat je ons niet gaat vertellen dat je evenveel kopieën van dit script hebt als dat er pagina's/vragen zijn, elk met verschillende ?paginaNR=X hyperlinks... Dat is niet het idee van dynamische webpagina's.
Wat ik zou doen is eens een stapje terugnemen, een kritische blik werpen op de aanpak (met name van de navigatie), en vervolgens het een en ander anders opzetten.
Ik hoop ook dat je ons niet gaat vertellen dat je evenveel kopieën van dit script hebt als dat er pagina's/vragen zijn, elk met verschillende ?paginaNR=X hyperlinks... Dat is niet het idee van dynamische webpagina's.
Wat ik zou doen is eens een stapje terugnemen, een kritische blik werpen op de aanpak (met name van de navigatie), en vervolgens het een en ander anders opzetten.




