为什么AJAX POST不起作用?

时间:2013-09-28 23:56:39

标签: php ajax

任何人都可以告诉我为什么我的 AJAX POST 无效......我添加了alert()它正在运行... idk这里哪里错了...这是我的代码...

<script language="JavaScript" type="text/javascript">
    function initialCalendar() {
        var hr = new XMLHttpRequest();
        var url = "calendar.php";
        var currentTime = new Date();
        var month = currentTime.getMonth() + 1;
        var year = currentTime.getFullYear();
        showmonth = month;
        showyear = year;
        var vars = "showmonth="+showmonth+"&showyear="+showyear;
        hr.open("POST", url, true);
        hr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
        hr.onreadystatechange = function() {
            if(hr.readyState == 4 && hr.status == 200) {
                var return_data = hr.responseText;
                document.getElementById("showCalendar").innerHTML = return_data;
            }
        }
        hr.send(vars);
        document.getElementById("showCalendar").innerHTML = "processing..";
        alert(vars);
    }

    function next_month(){
        var nextmonth = showmonth + 1;
        if(nextmonth > 12) {
            nextmonth = 1;
            showyear = showyear + 1;
        }
        showmonth = nextmonth;
        var hr = new XMLHttpRequest();
        var url = "calendar.php";
        var vars = "showmonth="+showmonth+"&showyear="+showyear;
        hr.open("POST", url, true);
        hr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
        hr.onreadystatechange = function() {
            if(hr.readyState == 4 && hr.status == 200) {
                var return_data = hr.responseText;
                document.getElementById("showCalendar").innertHTML = return_data;
            }
        }
        hr.send(vars);
        document.getElementById("showCalendar").innertHTML = "processing...";
        alert(vars);
    }

    function last_month(){
        var lastmonth = showmonth - 1;
        if(lastmonth < 1) {
            lastmonth = 1;
            showyear = showyear - 1;
        }
        showmonth = lastmonth;
        var hr = new XMLHttpRequest();
        var url = "calendar.php";
        var vars = "showmonth="+showmonth+"&showyear="+showyear;
        hr.open("POST", url, true);
        hr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
        hr.onreadystatechange = function() {
            if(hr.readyState == 4 && hr.status == 200) {
                var return_data = hr.responseText;
                document.getElementById("showCalendar").innertHTML = return_data;
            }
        }
        hr.send(vars);
        document.getElementById("showCalendar").innertHTML = "processing...";
        alert(vars);
    }
</script>

身体是

<body onLoad="initialCalendar();">
<div id="showCalendar"> </div>
</body>

和我以前和之前用过的按钮...... 这是calendar.php

<?php
$showmonth = $_POST['showmonth'];
$showyear = $_POST['showyear'];
$showmonth = preg_replace('#[^0-9]#i', '', $showmonth);
$showyear = preg_replace('#[^0-9]#i', '', $showyear);

$day_count = cal_days_in_month(CAL_GREGORIAN, $showmonth, $showyear);
$pre_days = date('w', mktime(0,0,0, $showmonth, 1, $showyear));
$post_days = (6 - (date('w', mktime(0,0,0, $showmonth, $day_count, $showyear))));


echo '<div class="title_bar">';
echo '<div class="previous_month"><input name="myBtn" type="submit" value="Previous Month" onClick="javascript:last_month();"></div>';
echo '<div class="show_month">' . $showmonth . '/' . $showyear . '</div>';
echo '<div class="next_month"><input name="myBtn2" type="submit" value="Next Month" onClick="javascript:next_month();"></div>';
echo '</div>';

1 个答案:

答案 0 :(得分:1)

innertHTMLinnerHTML功能中的next_month()更改为last_month()。我建议使用像Komodo Edit 7.1这样的编辑器。 (我认为这是Windows的最新免费版本。对Mac不确定。)