• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Javascript Google Distance Matrix Api, tylko w JS

Object Storage Arubacloud
0 głosów
168 wizyt
pytanie zadane 8 czerwca 2018 w JavaScript przez Mateusz Sobczyk Nowicjusz (120 p.)

Witam wszystkich.
Napisałem kod w html i Js który zwraca mi czas podróży samochodem z pkt A do pkt B. Problem w tym że jest on w html, a ja potrzebuję go w samej JavaScripcie by potem używać go w projekcie z javy. Wie ktoś jak mogę to umieścic w jednym skrypcie by działało prawidłowo ? tak aby ten script async src="https://maps.googleapis.com.... był w funkcji initMap. Kod programu:

DOCTYPE html>
<html>
  <head>
      <script async src="https://maps.googleapis.com/maps/api/js?key=AIzaSyD3NJp3ulVas-S9ef_F4CzKLzEloDBwmZE&callback=initMap"> </script>
      <div id="output"></div>
  <head>
  <body>
    <script>
      function initMap() {
      
      
        var origin = 'Sopocka 25, Wroclaw, Poland';//{lat: 51.116931, lng: 17.067401}; //51.116931, 17.067401
        var destination = {lat: 51.098039, lng: 16.994165};//51.098039, 16.994165
        var origin2 = 'Greenwich, England';
        var destinationA = 'Stockholm, Sweden';
    
        var geocoder = new google.maps.Geocoder;
        var service = new google.maps.DistanceMatrixService;
        var date = new Date(); date.setDate(date.getDate());
         
         DrivingOptions = {
            departureTime: date,
            trafficModel: 'optimistic'
        };
        
        service.getDistanceMatrix(
        {
        origins: [origin],
        destinations: [destination],
        travelMode: 'DRIVING',
        drivingOptions : DrivingOptions,
        unitSystem: google.maps.UnitSystem.METRIC,
        durationInTraffic: true,
        avoidHighways: false,
        avoidTolls: false
        },

        function(response, status) 
        {
            var origin = response.originAddresses[0];
            var destination = response.destinationAddresses[0];
            var outputDiv = document.getElementById('output'); outputDiv.innerHTML = '';

            var results = response.rows[0].elements;
            geocoder.geocode({'address': origin}, function(results, status){});
            geocoder.geocode({'address': destination}, function(results, status){});
            
            outputDiv.innerHTML += results[0].duration.value ;
                      
        });
      }

    </script>
  </body>
</html>

 

1 odpowiedź

0 głosów
odpowiedź 9 czerwca 2018 przez Chess Szeryf (76,710 p.)
edycja 9 czerwca 2018 przez Chess

Nie wiem, czy jest inny sposób niż tworzenie znacznika script dynamicznie.

https://developer.mozilla.org/en-US/docs/Web/API/HTMLScriptElement

W skrypcie dopisz tylko:

newScript.setAttribute('async','');

Po modyfikacji skryptu z MDN:

<body style="background:grey">

<script>
function loadError(oError) {
  throw new URIError("The script " + oError.target.src + " didn't load correctly.");
}

function affixScriptToHead(url, onloadFunction) {
  var newScript = document.createElement("script");
  newScript.onerror = loadError;
  if (onloadFunction) { newScript.onload = onloadFunction; }
  document.head.appendChild(newScript);
  newScript.src = url;
  newScript.setAttribute('async','');
}

affixScriptToHead('something1.js',function() {
	var x = 4;

	console.log(x+u);
    // result: 9
});
</script>

</body>

something1.js:

var u = 5;

https://www.nczonline.net/blog/2009/07/28/the-best-way-to-load-external-javascript/

Podobne pytania

0 głosów
0 odpowiedzi 125 wizyt
0 głosów
0 odpowiedzi 1,278 wizyt
pytanie zadane 2 lipca 2019 w JavaScript przez cyrus33 Użytkownik (680 p.)
0 głosów
1 odpowiedź 217 wizyt
pytanie zadane 17 sierpnia 2018 w JavaScript przez Gambr Dyskutant (7,530 p.)

92,551 zapytań

141,399 odpowiedzi

319,531 komentarzy

61,938 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...