将参数添加到现有 URL

Adding params to the existing URL

本文关键字:URL 参数 添加      更新时间:2023-09-26

基于使用 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 .我做错了什么?

应通过以下内容定义脚本标记:

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

而且您在以下方面还有一个语法错误:

// remove + before this.value    
<select name="idelev" onchange="insertParam('selected_valueelev',+this.value)">