繁体   English   中英

Joomla组件中的AJAX函数调用

[英]AJAX function call within Joomla Component

我对AJAX有很好的理解,通常在使用它时没有任何问题,但我对Joomla来说相对较新,并且最近才开始构建组件等。

我创建了一个使用“默认”视图的组件(命名目录)。 在这里,我有以下代码,这是一个AJAX调用:

<script type="text/javascript">                         
var url = "index.php?option=com_directory&view=directory&task=clubFilter&format=raw";
jQuery(document).ready(function() {
    jQuery('#city').change(function() {         

        jQuery.ajax({
            url: url,
            type: "POST",
            data: jQuery("#city").serialize(),
            dataType: 'json',
            success: function(data) {
                alert('data');
            }
        });
    });
});

在我的'views / directory / views.html'文件中,我创建了以下函数,该函数当前包含一个die,所以我可以确认它何时工作:

public function clubFilter() {
        die(print_r('here_i_am'));
    }

当我运行以下代码时,我在Firebugs控制台中出现以下错误。

'Error: 500 View not found [name, type, prefix]: directory, raw, directoryView'

我认为这是因为AJAX url var是不正确的,但是我从这里尝试了许多不同的解决方案和其他来源,并且无法使AJAX功能正常工作。 我的网址错了吗? 非常感谢

通常,我对控制器上的任务进行ajax调用。

这是我在我的一个扩展中使用的url格式,它使用对组件的ajax调用:

index.php?format=raw&option=<component_name_goes_here>&task=<task_goes_here>

然后,在我的组件的默认控制器中,我放了一个与任务名称相同的函数:

function getSomeData()
{
   echo(json_encode($data));//I normally return json
}

希望这可以帮助。

试试这个网址。 它可能会帮助你。

var url = "index.php?option=com_directory&view=directory&task=clubFilter&tmpl=component";

format=raw替换为&tmpl=component

否则,您也可以尝试以下格式。

jQuery.post('index.php',{
                        'option':'component_name',
                        'controller':'controller_name',
                        'task':'task_name',
                        'format':'raw',                   
                        'data': jQuery("#city").serialize(),
                        'dataType': 'json',
                },function(result){                     
                      //edit the result here

                    return;
       }); 

如果您对此有任何疑问,请不要犹豫。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM