0

我在OctoberCMS 中使用了默认的AJAX 框架,但现在我试图通过创建一个地图来使用更多定制的东西,该地图在平移时查询我的服务器以获取更多标记。为此,我需要定义一个端点,例如

/markers

我知道我可以创建一个页面来执行此操作,但这似乎很混乱,因为 OctoberCMS 中的默认设置是使用格式的函数

onPan()

我当前的javascript函数是:

var markerStore = {};

function getMarkers() {

    $.get('/markers', {}, function(res,resp) {
        for(var i=0, len=res.length; i<len; i++) {

            //Do we have this marker already?
            if(markerStore.hasOwnProperty(res[i].id)) {
                markerStore[res[i].id].setPosition(new google.maps.LatLng(res[i].position.lat,res[i].position.long));
            } else {
                var marker = new google.maps.Marker({
                    position: new google.maps.LatLng(res[i].position.lat,res[i].position.long),
                    title:res[i].name,
                    map:map
                }); 
                markerStore[res[i].id] = marker;
            }
        }
        window.setTimeout(getMarkers,INTERVAL);
    }, "json");
}

有没有办法可以调整它以使用 OctoberCMS 中的默认 AJAX 框架?如果不是,那么创建此页面的适当方法是什么?

4

2 回答 2

0

您可以使用 ajaxframeworks js api:(https://octobercms.com/docs/ajax/javascript-api#javascript-api

$.request('componentName::onGetMarkers', {
    success: function(data) {
        console.log(data);
    },
});
于 2017-11-08T09:39:11.803 回答
0

OctoberCMS 有自己的 AJAX 库,使用它你需要在控制器中创建方法,如你所说onPan()

但是你可以在插件的根目录下创建一个routes.php,即如果插件名称是blog,那么在blog文件夹下创建routes.php文件,使用laravel的路由和其他路由一样。

Route::get('markers',function(){
    // Use database of any computation to return markers 

});

现在您可以访问 www.example.com/markers 并将其用作带有 jQ​​uery AJAX 方法的 Native AJAX 调用。

于 2015-11-05T09:05:02.923 回答