Извлекать данные из базы данных, используя Ajax / jQuery в Laravel - PullRequest
1 голос
/ 24 июня 2019

Я хочу получить данные (долгота / широта) из базы данных и вернуть их для рисования нескольких маркеров на карте Google с помощью вызова Ajax.

Ниже приведен javascript, включающий ajax:

<script type='text/javascript'>

            (function(){

                var map,marker,latlng,bounds,infowin;
                /* initial locations for map */
                var _lat=5.441771999999999;
                var _lng=100.2936793;

                var id=1;

                function showMap(){
                    /* set the default initial location */
                    latlng={ lat: _lat, lng: _lng };

                    bounds = new google.maps.LatLngBounds();
                    infowin = new google.maps.InfoWindow();

                    /* invoke the map */
                    map = new google.maps.Map( document.getElementById('gmap'), {
                       center:latlng,
                       zoom: 15
                    });

                    /* show the initial marker */
                    marker = new google.maps.Marker({
                       position:latlng,
                       map: map,
                       title: 'Hello World!'
                    });
                    bounds.extend( marker.position );


                   $.ajaxSetup({
                        headers: {
                            'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
                        }
                    });

                    $.ajax({
                        type: 'GET',
                        url: '{{route("voyager.dashboard")}}',
                        data: {id:id},
                        success: function (response){

                           $.each(response, function( i,item ){
                                /* add a marker for each location in response data */ 
                                addMarker( item.latitude, item.longitude, item.location_status );
                            });
                        },
                        error: function(){
                            alert('There was an error loading the data.');

                        }
                    });                 
                }

                /* simple function just to add a new marker */
                function addMarker(lat,lng,title){
                    marker = new google.maps.Marker({/* Cast the returned data as floats using parseFloat() */
                       position:{ lat:parseFloat( lat ), lng:parseFloat( lng ) },
                       map:map,
                       title:title
                    });

                    google.maps.event.addListener( marker, 'click', function(event){
                        infowin.setContent(this.title);
                        infowin.open(map,this);
                        infowin.setPosition(this.position);
                    }.bind( marker ));

                    bounds.extend( marker.position );
                    map.fitBounds( bounds );
                }

                document.addEventListener( 'DOMContentLoaded', showMap, false );
            }());
        </script>

При установке ajax, когда я ставлю «dataType: json», выполняется ошибка функции.Выводом является предупреждение «Произошла ошибка при загрузке данных».

Это мой контроллер:

 public function _index(Request $request)
    {
        $locations = Location::select('latitude','longitude','location_status')->get();

        if( $locations ) {
            foreach( $locations as $location ) {
                $markers[]=array( 'latitude'=>$location->latitude, 'longitude'=>$location->longitude, 'location_status'=>$location->location_status );
            }
            return json_encode($markers, JSON_FORCE_OBJECT);     
        }

        return view('vendor.voyager.index');

Я попытался console.log (ответ), он отображает весь код JavaScript.

В настоящее время ошибка без «dataType:« json »» показывает «Uncaught TypeError: Невозможно использовать оператор« in »для поиска« length »..."

Я уже пытался это:

$.each(JSON.parse(response), function( i,item )

Показано сообщение об ошибке «Uncaught SyntaxError: неожиданный токен <в JSON в позиции 0 в JSON.parse () ..." </p>

Это маршрут в api.php:

Route::group(['middleware' => ['api']], function () {
    Route::get('/', ['uses' => 'VoyagerController@_index',   'as' => 'voyager.dashboard']);
});

Я не знаком с ajax / jQuery.Я впервые использую его.Надеюсь, кто-нибудь может мне помочь.Заранее спасибо.

1 Ответ

1 голос
/ 24 июня 2019

Измените свою функцию на

public function googleMarkers(Request $request)
    {
        $locations = Location::select('latitude','longitude','location_status')->get();

        return response()->json($locations);
}

Ваш маршрут до

Route::post('/', ['uses' => 'VoyagerController@googleMarkers',   'as' => 'gooogle.markers']);

И, как следствие, ваш Ajax-вызов

$.ajax({
   type: 'POST',
   url: '{{route("google.markers")}}',
   data: {id:id},
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...