AJAX 不发送数据,我无法使用 POST 结果



编辑:

我想在另一个页面中具有一个按钮值。我认为使用Ajax,但是我知道这是否是最好的方法。

这是我的表格:

<form id="form_prj">
    <button class="btn_prj" type="button" name="var_prj" value=60>Afficher</button>
</form>

这是我的 ajax:projet.php

$(document).ready(function() {
        $(document).on('click', '.btn_prj', function() {
            var sendData = {
                lid: this.value
            };
            $.ajax({
                type: 'POST',
                url: '../pit_app/carte.php',
                cache: false,
                data: {
                    lid: sendData,
                },
                success: function(data) {
                    console.log(data);
                    window.location = './carte.php';
                },
                error: function() {
                    alert("Error Occured");
                }
            });
        });

在这里 get_data.php

<?php
include('fonctions.php');
$connect = connect();
if(isset($_POST["lid"])) {
    $btn_value = $_POST['lid'];
}else{
    echo ("Error");
}
$sql1 = "SELECT row_to_json(fc)FROM (
    SELECT 'FeatureCollection' As type, array_to_json(array_agg(f)) As features 
    FROM (
    SELECT 'Feature' As type, ST_AsGeoJSON(ST_transform(ST_SetSRID(geom, 2154), 
    4326))::json As geometry, row_to_json(n) As properties 
    FROM chambre As n,projet WHERE ST_Contains(zone_etude,geom) and id_projet=" . $btn_value . ") As f)  As fc;";
$result = pg_query($connect, $sql1);
$rs = pg_fetch_array($result);
$legeojson = $rs[0];
?>

错误屏幕

edit2:

好吧,我将查询添加到Isset中,现在还有另一个问题。在我的第三个文件中,carte.php我包括get_data.php

我有 var geojson = </ br>但是我需要

var geojson = <?php echo $legeojson;?>;

注意:未定义的变量:legeojson in E: wamp www stage_axians pit_app carte.php在第108行

我已经对您的代码进行了一些小的清理。您的点击操作有点错了,要通过其名称获取按钮实例,您可以使用$('[name="var_prj"]'),这意味着$(this)将准确返回click事件正文中的此按钮

接下来,要从按钮value属性获取值,您可以使用$(this).attr('value'),如果要从input标签获得值,则可以使用简单的$(this).val()

最后一部分是AJAX调用的data参数。如果您已经有一个具有密钥和值的对象,则只需放入$.ajax

data参数
<form id="form_prj">
    <button type="button" name="var_prj" value=60>Afficher</button>
</form>
$(document).ready(function () {
        $('[name="var_prj"]').click(function () {
            var sendData = {
                lid: $(this).attr('value'),
            };
            $.ajax({
                type: 'POST',
                url: '../pit_app/carte.php',
                cache: false,
                data: sendData,
                success: function (data) {
                    window.location = './carte.php';
                },
                error: function () {
                    alert('Error Occured');
                },
            });
        });
    });

发送AJAX请求后,这是carte.php$_POST数组。

Array
(
    [lid] => 60
)

希望我的答案对您有帮助

最新更新