Prijsslider gegevens naar mysql versturen
Had graag iemand die wat wegwijs is met ajax, jquery, php & mysql naar mijn code laten kijken.
Ik ben bezig met een webshopje te maken om de verschillende codeer talen een beetje te leren kennen.
Ik ben momenteel toch al een paar dagen bezig met het proberen mijn priceslider aan de praat te krijgen.
Het lukt me maar niet wanneer je de price slider beweegt en dan los laat op een bepaalt bedrag deze te laten filteren in mysql zodat enkel de fietsen die tussen het bedrag (bijvoorbeeld: € 100 - € 500) te laten zien en de geen die er onder of er boven zit weg te filteren.
Index.php
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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
<?
include '../AdminPanel/Data.php';
require_once 'submit.php';
$sql = "SELECT MIN(Adviesprijs) AS minprijs, MAX(Adviesprijs) AS maxprijs FROM Fietsen";
$results = $pdo->query($sql);
foreach($results as $row) {
$minprijs = $row['minprijs'];
$maxprijs = $row['maxprijs'];
}
?>
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<title>jSlider</title>
<link rel="stylesheet" href="../prijsslider/jslider.css" type="text/css">
<script type="text/javascript" src="../prijsslider/js/jquery-1.7.1.js"></script>
<script type="text/javascript" src="../prijsslider/js/jshashtable-2.1_src.js"></script>
<script type="text/javascript" src="../prijsslider/js/jquery.numberformatter-1.2.3.js"></script>
<script type="text/javascript" src="../prijsslider/js/tmpl.js"></script>
<script type="text/javascript" src="../prijsslider/js/jquery.dependClass-0.1.js"></script>
<script type="text/javascript" src="../prijsslider/js/draggable-0.1.js"></script>
<script type="text/javascript" src="../prijsslider/js/jquery.slider.js"></script>
<style>
body {
padding: 10px;
}
h1 {
margin: 0 0 0.5em 0;
color: #343434;
font-weight: normal;
font-family: 'Ultra', sans-serif;
font-size: 36px;
line-height: 42px;
text-transform: uppercase;
text-shadow: 0 2px white, 0 3px #777;
}
h2 {
margin: 1em 0 0.3em 0;
color: #343434;
font-weight: normal;
font-size: 30px;
line-height: 40px;
font-family: 'Orienta', sans-serif;
}
#fietsen {
font-family: "Lucida Sans Unicode", "Lucida Grande", Sans-Serif;
font-size: 12px;
background: #fff;
margin: 15px 25px 0 0;
border-collapse: collapse;
text-align: center;
float: left;
width: 300px;
}
#fietsen th {
font-size: 14px;
font-weight: normal;
color: #039;
padding: 10px 8px;
border-bottom: 2px solid #6678b1;
}
#fietsen td {
border-bottom: 1px solid #ccc;
color: #669;
padding: 8px 10px;
}
#fietsen tbody tr:hover td {
color: #009;
}
#filter {
float:left;
}
</style>
</head>
<body>
<h1>TEST DATABASE</h1>
<table id="fietsen">
<thead>
<tr>
<th>ID</th>
<th>Soortfiets</th>
<th>Model</th>
<th>Adviesprijs</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
<div id="filter">
<h2>Filter opties</h2>
<div>
<? if ($Kinder != '0'){?>
<input type="checkbox" id="Kinder" >
<label for="Kinder">Kinderfiets <? echo '('.$Kinder.')' ?></label>
</div><div>
<? } if ($Vouw != '0'){?>
<input type="checkbox" id="Vouw" name="Vouw" >
<label for="Vouw">Vouwfiets <? echo '('.$Vouw.')' ?></label>
</div><div>
<? } if ($Stads != '0'){?>
<input type="checkbox" id="Stads" name="Stads" >
<label for="Stads">Stadsfiets <? echo '('.$Stads.')' ?></label>
</div><div>
<? } if ($Elektrische != '0'){?>
<input type="checkbox" id="Elektrische" name="Elektrische" >
<label for="Elektrische">Elektrischefiets <? echo '('.$Elektrische.')' ?></label>
</div><div>
<? } if ($Fitness != '0'){?>
<input type="checkbox" id="Fitness" name="Fitness" >
<label for="Fitness">Fitnessfiets <? echo '('.$Fitness.')' ?></label>
</div><div>
<? } if ($Hybride != '0'){?>
<input type="checkbox" id="Hybride" name="Hybride" >
<label for="Hybride">Hybridefiets <? echo '('.$Hybride.')' ?></label>
</div><div>
<? } if ($MTB != '0'){?>
<input type="checkbox" id="MTB" name="MTB" >
<label for="MTB">Mountainbike <? echo '('.$MTB.')' ?></label>
</div><div>
<? } if ($Koers != '0'){?>
<input type="checkbox" id="Koers" name="Koers" >
<label for="Koers">Koersfiets <? echo '('.$Koers.')' ?></label>
<? } ?>
</div>
</div>
<div>
<span style="display: inline-block; width: 400px; padding: 0 5px;">
<input id="prijsslider" type="slider" name="price" value="<? echo $minprijs.';'.$maxprijs;?>" /></span>
<script type="text/javascript" charset="utf-8">
jQuery("#prijsslider").slider(
{ from: <? echo $minprijs; ?>, to: <? echo $maxprijs; ?>, step: 10, smooth: true, round: 0, dimension: " ", skin: "plastic" });
</script>
</div>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>
function makeTable(data){
var tbl_body = "";
$.each(data, function() {
var tbl_row = "",
currRecord = this;
$.each(this, function(k , v) {
if(k==='model'){
v = "<a href='content.php?id=" + currRecord['id'] +"'>" + v + "</a>";
} else if (k==='Adviesprijs'){
v = "<span class='Adviesprijs'>" + v + "</span>";
}
tbl_row += "<td>"+v+"</td>";
})
tbl_body += "<tr>"+tbl_row+"</tr>";
})
return tbl_body;
}
function getfietsFilterOptions(){
var opts = [];
$checkboxes.each(function(){
if(this.checked){
opts.push(this.id);
}
});
return opts;
}
function updatefietsen(opts){
if(!opts || !opts.length){
opts = allemerken;
}
$.ajax({
type: "POST",
url: "submit.php",
dataType : 'json',
cache: false,
data: {filterOpts: opts},
success: function(records){
$('#fietsen tbody').html(makeTable(records));
updatePrijzen();
}
});
}
function updatePrijzen(){
var subsidyTotal = Number($("#total").text());
$(".Adviesprijs").each(function(){
var origVal = Number($(this).text())
$(this).text(origVal - subsidyTotal)
})
}
var $checkboxes = $("input:checkbox");
$checkboxes.on("change", function(){
var opts = getfietsFilterOptions();
updatefietsen(opts);
});
$("#remove").on("click", function(){
$("#total").text("0");
$(this).prop("disabled", true);
$(this).prev().prop("disabled", false);
$checkboxes.trigger("change");
});
var allemerken = [];
$("input[type=checkbox]").each(function(){
allemerken.push($(this)[0].id)
})
updatefietsen();
updatePrijzen();
</script>
</body>
</html>
include '../AdminPanel/Data.php';
require_once 'submit.php';
$sql = "SELECT MIN(Adviesprijs) AS minprijs, MAX(Adviesprijs) AS maxprijs FROM Fietsen";
$results = $pdo->query($sql);
foreach($results as $row) {
$minprijs = $row['minprijs'];
$maxprijs = $row['maxprijs'];
}
?>
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<title>jSlider</title>
<link rel="stylesheet" href="../prijsslider/jslider.css" type="text/css">
<script type="text/javascript" src="../prijsslider/js/jquery-1.7.1.js"></script>
<script type="text/javascript" src="../prijsslider/js/jshashtable-2.1_src.js"></script>
<script type="text/javascript" src="../prijsslider/js/jquery.numberformatter-1.2.3.js"></script>
<script type="text/javascript" src="../prijsslider/js/tmpl.js"></script>
<script type="text/javascript" src="../prijsslider/js/jquery.dependClass-0.1.js"></script>
<script type="text/javascript" src="../prijsslider/js/draggable-0.1.js"></script>
<script type="text/javascript" src="../prijsslider/js/jquery.slider.js"></script>
<style>
body {
padding: 10px;
}
h1 {
margin: 0 0 0.5em 0;
color: #343434;
font-weight: normal;
font-family: 'Ultra', sans-serif;
font-size: 36px;
line-height: 42px;
text-transform: uppercase;
text-shadow: 0 2px white, 0 3px #777;
}
h2 {
margin: 1em 0 0.3em 0;
color: #343434;
font-weight: normal;
font-size: 30px;
line-height: 40px;
font-family: 'Orienta', sans-serif;
}
#fietsen {
font-family: "Lucida Sans Unicode", "Lucida Grande", Sans-Serif;
font-size: 12px;
background: #fff;
margin: 15px 25px 0 0;
border-collapse: collapse;
text-align: center;
float: left;
width: 300px;
}
#fietsen th {
font-size: 14px;
font-weight: normal;
color: #039;
padding: 10px 8px;
border-bottom: 2px solid #6678b1;
}
#fietsen td {
border-bottom: 1px solid #ccc;
color: #669;
padding: 8px 10px;
}
#fietsen tbody tr:hover td {
color: #009;
}
#filter {
float:left;
}
</style>
</head>
<body>
<h1>TEST DATABASE</h1>
<table id="fietsen">
<thead>
<tr>
<th>ID</th>
<th>Soortfiets</th>
<th>Model</th>
<th>Adviesprijs</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
<div id="filter">
<h2>Filter opties</h2>
<div>
<? if ($Kinder != '0'){?>
<input type="checkbox" id="Kinder" >
<label for="Kinder">Kinderfiets <? echo '('.$Kinder.')' ?></label>
</div><div>
<? } if ($Vouw != '0'){?>
<input type="checkbox" id="Vouw" name="Vouw" >
<label for="Vouw">Vouwfiets <? echo '('.$Vouw.')' ?></label>
</div><div>
<? } if ($Stads != '0'){?>
<input type="checkbox" id="Stads" name="Stads" >
<label for="Stads">Stadsfiets <? echo '('.$Stads.')' ?></label>
</div><div>
<? } if ($Elektrische != '0'){?>
<input type="checkbox" id="Elektrische" name="Elektrische" >
<label for="Elektrische">Elektrischefiets <? echo '('.$Elektrische.')' ?></label>
</div><div>
<? } if ($Fitness != '0'){?>
<input type="checkbox" id="Fitness" name="Fitness" >
<label for="Fitness">Fitnessfiets <? echo '('.$Fitness.')' ?></label>
</div><div>
<? } if ($Hybride != '0'){?>
<input type="checkbox" id="Hybride" name="Hybride" >
<label for="Hybride">Hybridefiets <? echo '('.$Hybride.')' ?></label>
</div><div>
<? } if ($MTB != '0'){?>
<input type="checkbox" id="MTB" name="MTB" >
<label for="MTB">Mountainbike <? echo '('.$MTB.')' ?></label>
</div><div>
<? } if ($Koers != '0'){?>
<input type="checkbox" id="Koers" name="Koers" >
<label for="Koers">Koersfiets <? echo '('.$Koers.')' ?></label>
<? } ?>
</div>
</div>
<div>
<span style="display: inline-block; width: 400px; padding: 0 5px;">
<input id="prijsslider" type="slider" name="price" value="<? echo $minprijs.';'.$maxprijs;?>" /></span>
<script type="text/javascript" charset="utf-8">
jQuery("#prijsslider").slider(
{ from: <? echo $minprijs; ?>, to: <? echo $maxprijs; ?>, step: 10, smooth: true, round: 0, dimension: " ", skin: "plastic" });
</script>
</div>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>
function makeTable(data){
var tbl_body = "";
$.each(data, function() {
var tbl_row = "",
currRecord = this;
$.each(this, function(k , v) {
if(k==='model'){
v = "<a href='content.php?id=" + currRecord['id'] +"'>" + v + "</a>";
} else if (k==='Adviesprijs'){
v = "<span class='Adviesprijs'>" + v + "</span>";
}
tbl_row += "<td>"+v+"</td>";
})
tbl_body += "<tr>"+tbl_row+"</tr>";
})
return tbl_body;
}
function getfietsFilterOptions(){
var opts = [];
$checkboxes.each(function(){
if(this.checked){
opts.push(this.id);
}
});
return opts;
}
function updatefietsen(opts){
if(!opts || !opts.length){
opts = allemerken;
}
$.ajax({
type: "POST",
url: "submit.php",
dataType : 'json',
cache: false,
data: {filterOpts: opts},
success: function(records){
$('#fietsen tbody').html(makeTable(records));
updatePrijzen();
}
});
}
function updatePrijzen(){
var subsidyTotal = Number($("#total").text());
$(".Adviesprijs").each(function(){
var origVal = Number($(this).text())
$(this).text(origVal - subsidyTotal)
})
}
var $checkboxes = $("input:checkbox");
$checkboxes.on("change", function(){
var opts = getfietsFilterOptions();
updatefietsen(opts);
});
$("#remove").on("click", function(){
$("#total").text("0");
$(this).prop("disabled", true);
$(this).prev().prop("disabled", false);
$checkboxes.trigger("change");
});
var allemerken = [];
$("input[type=checkbox]").each(function(){
allemerken.push($(this)[0].id)
})
updatefietsen();
updatePrijzen();
</script>
</body>
</html>
submit.php
Code (php)
1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
<?php
include '../AdminPanel/Config.php';
$opts = $_POST['filterOpts'];
$qMarks = str_repeat('?,', count($opts) - 1) . '?';
$statement = $pdo->prepare("SELECT Fietsen.id, Typefiets, Model, Adviesprijs
FROM Fietsen INNER JOIN Soortfiets ON Soortfiets_id = Soortfiets.id WHERE Typefiets IN ($qMarks)");
$statement -> execute($opts);
$results = $statement -> fetchAll(PDO::FETCH_ASSOC);
$json = json_encode($results);
echo($json);
?>
include '../AdminPanel/Config.php';
$opts = $_POST['filterOpts'];
$qMarks = str_repeat('?,', count($opts) - 1) . '?';
$statement = $pdo->prepare("SELECT Fietsen.id, Typefiets, Model, Adviesprijs
FROM Fietsen INNER JOIN Soortfiets ON Soortfiets_id = Soortfiets.id WHERE Typefiets IN ($qMarks)");
$statement -> execute($opts);
$results = $statement -> fetchAll(PDO::FETCH_ASSOC);
$json = json_encode($results);
echo($json);
?>
http://tinyurl.com/n23rmaj
Is de pagina waar ik momenteel een beetje op aant prutsen ben
Alvast bedankt
Is de pagina waar ik momenteel een beetje op aant prutsen ben
Alvast bedankt
Gewijzigd op 29/07/2014 22:31:51 door Jaimy A
Overigens laadt je op regel 154 nogmaals jQuery.
Gewijzigd op 29/07/2014 12:20:33 door Ger van Steenderen
Ger van Steenderen op 29/07/2014 12:19:47:
is nog een overblijfsel van mijn testjes :p
ik weet enkel niet goed hoe ik in ajax/jquery een listner maak die luister wanneer ik mijn price slider verschuif en los laat en dan zeg op welk bedrag deze staat en deze dan door stuurt naar php zodat ik deze request kan versturen naar mysql