我正在尝试使用 jQuery 加载图像(使用 PHP 创建)并传递一些变量(例如:)picture.php?user=1&type=2&color=64
。那是容易的部分。
困难的部分是我有一个下拉菜单,可以让我选择背景(类型参数),并且我将有一个输入,例如选择颜色。
这是我面临的问题:
- 如果没有触及下拉/输入,我想将其排除在 URL 之外。
- 如果已触摸下拉/输入,我想将其包含在 url 中。(这不会通过将变量“
&type=2
”添加到预先存在的字符串来工作,就好像我多次触摸下拉/输入它们会堆叠(&type=2&type=2&type=3
)一样)。 - 将变量(“
&type=2
” - 参见下面的代码)添加到预先存在的 URL 时,& 符号会消失(变成这样:“signature.php?user=1type=2
”)。
这是jQuery的代码:
<script>
var url = "signatureload.php?user=<?php echo $_SESSION['sess_id']; ?>";
$(document).ready(function() {
window.setTimeout(LoadSignature, 1500);
});
$("#signature_type").change(function() {
url += "&type="+$(this).val();
LoadSignature();
});
function LoadSignature()
{
$("#loadingsignature").css("display", "block");
$('#loadsignature').delay(4750).load(url, function() {
$("#loadingsignature").css("display", "none");
});
}
</script>
这是我加载图像的代码:
<div id="loadsignature">
<div id="loadingsignature" style="display: block;"><img src="img/loading-black.gif" alt="Loading.."></div>
</div>
我不知道我还能进一步解释我的问题。如果您有任何疑问或需要更多代码,请告诉我。
谢谢您的帮助!
编辑:
这是当前代码:
<script>
var url = "signatureload.php?user=<?php echo $_SESSION['sess_id']; ?>";
$(document).ready(function() {
window.setTimeout(LoadSignature, 1500);
});
$("#signature_type").change(function() {
url = updateQueryStringParameter(url, 'type', $(this).val());
LoadSignature();
});
function LoadSignature()
{
$("#loadingsignature").css("display", "block");
$('#loadsignature').delay(4750).load(url, function() {
$("#loadingsignature").css("display", "none");
});
}
function updateQueryStringParameter(uri, key, value)
{
var re = new RegExp("([?&])" + key + "=.*?(&|$)", "i"),
separator = uri.indexOf('?') !== -1 ? "&" : "?",
returnUri = '';
if (uri.match(re))
{
returnUri = uri.replace(re, '$1' + key + "=" + value + '$2');
}
else
{
returnUri = uri + separator + key + "=" + value;
}
return returnUri;
}
</script>
编辑2:
这是 signatureload.php 的代码
<?php
$url = "signature.php?";
$count = 0;
foreach($_GET as $key => $value)
{
if($count > 0) $url .= "&";
$url .= "{$key}={$value}";
}
echo "<img src='{$url}'></img>";
?>