javascript - 通过 Ajax 通过变量将多个变量传递给 PHP 不起作用

标签 javascript php jquery ajax url

我想使用 Ajax 通过 URL 传递三个变量,其中一个是常量,另外两个来自日期选择器。我能够很好地传递常量,但是日期变量只是作为变量名称传递。

下面是日期选择器的代码:

        <tr>
            <td>
                <input type="text" id="range1" size="10" data-datepick="rangeSelect: true, minDate: 'new Date()'"/>
            </td>
            <td>
                <input type="text" id="range2" size="10" data-datepick="rangeSelect: true, minDate: 'new Date()'"/>
            </td>
            <td>
                <button type="button" onclick="dateRangeFunction()">Go</button>
            </td>   
        </tr>

变量 range1 和 range2 包含要传递的日期,创建 URL 并传递变量的函数如下:

        function dateRangeFunction() {
            var range1 = document.getElementById('range1').value;
            var range2 = document.getElementById('range2').value;

            if(range1 == null || range1=="") {
                alert("Please Select A Date To Search From");
                return;
            }
                $.ajax({
                    type: 'GET',
                    url: 'daterangedetails.php?pt=7&rngstrt=" + range1 + "&rngfin=" + range2',
                    success: function (data) {
                    document.getElementById('rangeDetails').innerHTML = data;
                    }
                });
            }           
</script>

对两个变量执行警报会显示所选的正确日期,但是当通过 URL 传递并使用 $_GET 回显 daterangedetails.php 中 rngstrt 和 rngfin 上的结果变量时,只会将变量名称指定为“range1” & "range2.pt值传递正确。

用于回显变量的代码是:

<?php
session_start();

include 'dbconnect.php';

$dateFrom = $_GET['rngstrt'];
$dateTo = $_GET['rngfin'];
$rangeType = $_GET['pt1'];

echo "Date From: ".$_GET['rngstrt']."<br/>";
echo "Date To: ".$dateTo."<br/>";
echo "Date: ".$criteriaDate."<br/>";
echo "Type: ".$rangeType;
?>

任何帮助将不胜感激,我在想也许我必须将变量放入数组中?但我不确定该怎么做,如果这就是我应该做的。

最佳答案

function dateRangeFunction() {
        var range1 = $('range1').val;
        var range2 = $('range2').val;

        if(range1 == null || range1=="") {
            alert("Please Select A Date To Search From");
            return;
        }
            $.ajax({
               type  : 'GET',
                url  : 'daterangedetails.php',
                data : {pt:'7',rngstrt:range1, rngfin:range2},
                success: function (data) {
                document.getElementById('rangeDetails').innerHTML = data;
                }
            });
        }           

关于javascript - 通过 Ajax 通过变量将多个变量传递给 PHP 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28271867/

相关文章:

javascript - 如何在矩形的底部svg JS中绘制圆 Angular

c# - jquery ajax 'post' 调用

javascript - 单击按钮时飞入内容框?

javascript - 我如何知道一次切换了多少个 Waypoints 实例?

javascript - AddEventListener IE 11 中调用对象无效

php - HTML 表单 -> Mysql

php - XDebug 跟踪中内存值的单位是什么?

javascript - 进行奇特的文件输入时未捕获类型错误

jquery - 为什么我的验证没有显示?

javascript - 如何匹配正则表达式中的非 ASCII(德语、西类牙语等)字母?