如何在PHP中使用jQuery变量

时间:2014-03-04 12:11:57

标签: php jquery

我在PHP中使用 MVC ,我在表单页面中创建了此脚本以验证三个文本框。当这三个文本框包含一个值时,我的控制器中的php代码会根据这三个字段的输入向Google Map Api询问最近的方向。

在我的脚本中,我有变量“direccion”,这是我需要使用PHP传递给控制器​​,但我不知道如何实现这一点。

脚本代码(查看)

jQuery(document).ready(function () {

    var direccion="";
    var flag = false;
    jQuery(".validation").change(function () {
        flag = true;
        jQuery(".validation").each(function () {
            if (jQuery(this).val().trim() == "") {
                alert("false");
                flag = false;
            }
        });
        if (flag==true) {

            var calle = jQuery("#ff_elem295").val();
            var municipio = jQuery("#id_municipio option:selected").text();
            var provincia = jQuery("#id_provincia option:selected").text();             

            direccion = calle +","+ municipio +","+ provincia;
            direccion = direccion.replace(/\s/g,'+');
            //alert(direccion);
        }       
});

jQuery.ajax({
            url: "index.php?option=com_cstudomus&controller=saloninmobiliarios&task=calcularDistancias",
            data : direccion,
            dataType : 'html'
        }).done(function(){
                var data = data;
        });
});

PHP代码(控制器)

function calcularDistancias(){

    $valor = JRequest::getVar('direccion');

    $url =  'http://maps.googleapis.com/maps/api/geocode/json?address='. $valor .'&sensor=false';

    $data = file_get_contents($url);

    $data_array = json_decode($data,true);

    $lat = $data_array[results][0][geometry][location][lat];
    $lng = $data_array[results][0][geometry][location][lng];
......
}

3 个答案:

答案 0 :(得分:4)

传递给jQuery.ajax的对象中的

data属性是一个对象。

data : { direccion: direccion }

然后,您可以在控制器中访问direccion的值作为请求参数。

答案 1 :(得分:1)

if条件中输入您的ajax请求

if(flag == true) {
    jQuery.ajax({
        url: "index.php?option=com_cstudomus&controller=saloninmobiliarios&task=calcularDistancias",
        data : {direction : direccion},
        dataType : 'html'
    }).done(function(){
            var data = data;
    });
}

答案 2 :(得分:0)

此外,您的代码中缺少检索到的数据,请不要忘记将数据放入done函数中:

.done(function(){
    var data = data;
});

.done(function(data){
    var data = data;
});