0

基于使用 JavaScript 向 URL 添加参数,我尝试制作一个脚本,将参数添加到现有 URL 但有点失败,我不知道为什么......

    <script type="javascript">
    function insertParam(key, value)
    {
        key = encodeURI(key); value = encodeURI(value);
        var kvp = document.location.search.substr(1).split('&');
        var i=kvp.length; var x; while(i--) 
        {
            x = kvp[i].split('=');
            if (x[0]==key)
            {
                x[1] = value;
                kvp[i] = x.join('=');
                break;
            }
        }
        if(i<0) {kvp[kvp.length] = [key,value].join('=');}
        //this will reload the page, it's likely better to store this until finished
        document.location.search = kvp.join('&'); 
    }
</script>
<label>
    <select name="id" onchange="window.location='somepage.php?page=inserari-note&selected_value='+this.value">
    <option>--Alege user--</option>
        <?php 
            while($runrows = mysql_fetch_assoc($run))
            {
                $user = $runrows ['user_login'];
                echo"<option value=\"$user\">$user</option>";
            }
        ?>
    </select>
</label>
<label>
    <select name="idelev" onchange="insertParam('selected_valueelev',+this.value)">
    <option>--Alege Elev--</option>
        <?php 
            while($runrows4 = mysql_fetch_assoc($run4))
            {
                $elev = $runrows4 ['Nume'];
                echo"<option value=\"$elev\">$elev</option>";
            }
        ?>
    </select>
</label>

因此,第一个select是用学生填充第二个select,并将 URL 更改为somepage.php?page=inserari-note&selected_value='+this.value效果很好,但是当我单击第二个中的选项时select,什么也没有发生。在我看来,它应该在我之前提到的现有 URL 中添加值&selected_valueelev="chosen-option",以便 URL 看起来像我们说的那样somepage.php?page=inserari-note&selected_value=user&selected_valueelev=student。我究竟做错了什么?

4

1 回答 1

0

您应该通过以下方式定义脚本标签:

<script type="text/javascript">
...
</script>

而且您还有以下语法错误:

// remove + before this.value    
<select name="idelev" onchange="insertParam('selected_valueelev',+this.value)">
于 2013-10-01T15:38:05.557 回答