表单输入数组$ _GET逗号分隔在URL中

时间:2013-11-16 14:19:42

标签: php arrays forms get

我有一张表格:

<form action="results.php" method="get">
<select name="genres[]">
<option value="jazz"></option>
<option value="blues"></option>
<option value="rock"></option>
</select>
</form>

提交表单后,在网址中输入变为example.com/?genres%5B%5D=jazz&genres%5B%5D=blues&genres%5B%5D=rock

接下来它看起来不太好,我的表单中有多个输入(大约18种类型),所以如果用户选择了很多,则URL会变得很长。我希望它成为/?genres = jazz,blues,rock

现在我已阅读this post,但它没有说明如何制作更清晰的网址。接下来,我必须将输入用作数组,例如$genres = $_GET['genres']以用于另一个函数。

1 个答案:

答案 0 :(得分:1)

你可以这样做:

<!doctype html>
<html>
<head>
    <script src="http://code.jquery.com/jquery-1.10.2.min.js"></script>

    <script>
        $(document).ready(function(){
           $("#go").click(function(){
               var g = $("#genres").val();
               var href = 'results.php?genres=';
               if(g != null) {
                   href += g;
               }
               document.location.href=href;
           });
        });
    </script>
</head>
<body>    
<select id="genres" size="3" multiple>
<option value="jazz">jazz</option>
<option value="blues">blues</option>
<option value="rock">rock</option>
</select>
<input type="button" value="go" name="submit" id="go">
</body>
</html>

在results.php中你应该:

$g = isset($_GET['genres'])?$_GET['genres']:"";
$genres = explode(",",$g);

我已完全删除表单,因为类型现在由document.location.href发送。 jquery的.val()函数返回所选的值,如预期的(,内爆)