javascript - 将 javascript 变量传递给 ruby​​ on rails Controller 以进一步发送 api

标签 javascript ruby-on-rails api google-maps-api-3 uber-api

我有一个 google api 映射作为 index.html

<!DOCTYPE html>
<html>
<head>

<meta name="viewport" content="initial-scale=1.0, user-scalable=no">
<meta charset="utf-8">
<style>
  html, body {
    height: 100%;
    margin: 0;
    padding: 0;
  }
  #map {
    height: 100%;
  }
</style>
</head>
<body>
<div id="map"></div>
<script>
  // Note: This example requires that you consent to location sharing when
  // prompted by your browser. If you see the error "The Geolocation service
  // failed.", it means you probably did not give permission for the browser to
  // locate you.

  function initMap() {
    var map = new google.maps.Map(document.getElementById('map'), {
      center: {lat: -34.397, lng: 150.644},
      zoom: 15
    });
    var infoWindow = new google.maps.InfoWindow({map: map});

    // Try HTML5 geolocation.
    if (navigator.geolocation) {
      navigator.geolocation.getCurrentPosition(function(position) {
        var pos = {
          lat: position.coords.latitude,
          lng: position.coords.longitude
        };

        infoWindow.setPosition(pos);
        infoWindow.setContent('Location found.');
        map.setCenter(pos);
      }, function() {
        handleLocationError(true, infoWindow, map.getCenter());
      });
    } else {
      // Browser doesn't support Geolocation
      handleLocationError(false, infoWindow, map.getCenter());
    }
  }

  function handleLocationError(browserHasGeolocation, infoWindow, pos) {
    infoWindow.setPosition(pos);
    infoWindow.setContent(browserHasGeolocation ?
                          'Error: The Geolocation service failed.' :
                          'Error: Your browser doesn\'t support geolocation.');
  }



    </script>
    <script async defer
src="https://maps.googleapis.com/maps/api   /js?key=AIzaSyBNvjq57_K8vPYRKETMN6bDogqCpRvBoA0&callback=initMap">
    </script>
    </body>
    </html>

我想在 ruby​​ on rails Controller 中使用 var=pos,即产品 Controller

require 'rubygems'

    require 'httparty'

    class ProductsController < ApplicationController



def index

    @results = HTTParty.get("https://api.uber.com          /v1/products?server_token=xyz&latitude=37.7759792&longitude=-122.41823").parsed_response

   respond_to do |format|
   format.json { render :json => JSON.parse(@results) }
   format.html { render "index.html.erb" }
   end
   end
   end

然后在 api url 中传递单独的纬度和经度,以便它可以采用任何纬度和经度,而不是手动提供。 我该怎么做 ?任何建议将不胜感激。

最佳答案

正如@max 所说,您必须向 Controller 发出另一个请求。如果您使用 jQuery 并想发出 AJAX 请求,可以这样做:

$.ajax({
  method: "GET",
  url: "products/some_action",
  data: { lat: pos.lat, lng: pos.lng }
})
.done(function( msg ) {
  alert( "Done" );
});

参见 http://api.jquery.com/jquery.ajax/

并在您的 ProductsController 中添加:

def some_action
  # do something with params[:lat] and params[:lng]
end

关于javascript - 将 javascript 变量传递给 ruby​​ on rails Controller 以进一步发送 api,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37411903/

相关文章:

javascript - 将 Angular.js 应用程序直接连接到 Dynamodb 是否有意义? AngularJS 中删除后端的替代方案?

ruby-on-rails - 将 Warbler 制作的 .war 部署到 Tomcat

ios - RestKit 0.20 嵌套对象映射问题使用 API

javascript - 我正在尝试获取我的 json 站点以启用 API,但出现错误 "Unexpected token < in JSON at position 0"

ruby-on-rails - 从 activerecord 中的组中选择最小值

api - 如何检查数据集对于 WEKA api 中的某些分类是否有效?

javascript - 使用 array.includes 进行松散相等比较

javascript - 使用 GraalVM 在 Java 中评估 JavaScript

css - 没有 javascript 的响应式网页设计,适用于 IE <=8。是否可以?

ruby-on-rails - Kubernetes-ReplicationController和永久磁盘