ajax 响应后值未更新

IT技术 javascript ajax jquery
2021-02-24 03:19:29

我正在通过 ajax 将一些表单数据发送到同一页面中的 php 脚本。PHP 必须处理数据并在同一页面中显示结果。

我在 ajax 中使用这种语法:

$.ajax
({
    type: "POST",
    url: "",
    data: $("form").serialize(),
    success: function(result)
    {
        updatechart();
       console.log(result);
    }
});  

我基本上是在尝试根据表单中输入的数据和 php 脚本处理后的数据更新图表中的一些值。当我这样做时,我获得了页面的整个源代码,console.log(result);并且在执行此操作后,我的控制台中的值会更新,但图表未更新。当我查看源页面时,值保持不变。我该怎么办?

    function updatechart() {
        var json=<?php echo json_encode($GLOBALS['json']); ?>;
        var direct=json['direct'];
        var total=json['total'];
        var referred=total-direct;
        var aid=new Array();
        var count=new Array();
        for(var i=0;i<json['aid'].length;i++) {
            aid[i]=json['aid'][i];
            count[i]=json['count'][i];
        }
    var series = [{
                name : "Referred",
                data: [referred]
            }, {
                name: "Direct",
                data: [direct]
            }];
       for(var i=0; i<aid.length;i++) {
            series.push({
                name: 'AID-'+[aid[i]],
                data: [count[i]]
            })
        }
    var options = {
        chart: {
            renderTo: 'container',
            type: 'column'
        },
        title: {
            text: 'User Source Chart'
        },
        xAxis: {
            categories: ['Users']
        },
        yAxis: {
            min: 0,
            title: {
                text: 'Total users'
            }
        },
        tooltip: {
            pointFormat: '<span style="color:{series.color}">{series.name}</span>: <b>{point.y}</b> ({point.percentage:.0f}%)<br/>',
            shared: true
        },
        plotOptions: {
            column: {
                stacking: 'percent'
            }
        },
            series: series
    };
    chart = new Highcharts.Chart(options); 
}

这是我的 updatechart() 代码。问题是,json 值没有更新。

2个回答

resultas参数传递updatechart()

$.ajax
({
    type: "POST",
    url: "",
    data: $("form").serialize(),
    success: function(result)
    {
        updatechart(result);      
    }
}); 

然后通过参数访问结果

function updatechart(result) {
//.......
//.......
console.log(result);
}

希望你正在尝试这样的事情。

@user2510555 这可能是因为您的 PHP 仍在设置全局而不是返回 json。(通过回声)
2021-04-17 03:19:29
@user2510555 你的ajax返回什么? result = undefined,那么ajax调用有什么用呢?
2021-05-05 03:19:29
@user1671639 当我console.log(result);在成功函数中执行时,它会返回带有更新值的整个页面
2021-05-05 03:19:29
是的,这是正确的方法,但看起来 OP 正在响应整个页面......
2021-05-06 03:19:29

这是预期的行为。将您的 PHP 处理移动到不同的页面。

$.ajax
({
    type: "POST",
    url: "anotherphppage.php",
    data: $("form").serialize(),
    success: function(result)
    {
        updatechart(result);      
    }
}); 

试试这个,你会明白我的意思:

<html>
    <head>
        <script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>

        <script type="text/javascript">
            $(document).ready(function() {

                $('#mybutt').click(function() {
                    $.ajax({
                        type: "POST",
                        url: "",
                        data: 'myVar=Hello',
                        success: function(data) {
                            alert(data);
                        }
                    });
                });
            }); //END $(document).ready()

        </script>
    </head>
<body>

    Try this:<br />
    <input type="button" id="mybutt" value="Click Me">

</body>
</html>