0

現在、Google Maps JavaScript API V3 を使用して地図の結果をフィルタリングしています。2 つの JavaScript ドロップダウン メニューがあります。ドロップダウン オプションの値を 1 つ選択すると、マップはその設定でフィルター処理されます。そのため、ビジネスの種類に「社会サービス」を選択すると、マップにはこの種類のビジネスのみが表示されます。2 番目のフィルターは、別の主題をフィルター処理します。したがって、2 番目のドロップダウン メニューが選択されている場合、このオプション値にフィルターされます。問題は、2 番目または 1 番目が選択されると、フィルタリングで他方が無視されることです。たとえば、ユーザーが最初のメニューから「社会サービス」を、2 番目のメニューから「商談」をフィルタリングできるようにしたいと考えています。これにより、両方の基準を満たす場所が表示されます。現在、ユーザーはどちらか一方しか選択できません。

ここにページがあります:

LTI マップ

コードは次のとおりです。

    <html> 
<head> 
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" /> 
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/> 
<!DOCTYPE html>
<title>Met Sacramento Internship Map</title> 

<!-- Style --> 
<style> 
  body { font-family: Arial, sans-serif; }
  #map_canvas { height: 500px; width:600px; }
</style> 

<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script> 
<script type="text/javascript"> 
    var tableid = 567682;
    var layer = new google.maps.FusionTablesLayer(567682); 

  function initialize() {
    var latlng = new google.maps.LatLng(38.59970036588819, -121.541748046875);
    var myOptions = {
      zoom: 8,
      center: latlng,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    };
    var map = new google.maps.Map(document.getElementById("map_canvas"),
        myOptions);
          layer.setMap(map);
  }
    //Change the query based on the user's selection
function interestMap(interest) {
 layer.setQuery("SELECT Address, 'Interest Area' FROM " + tableid + " WHERE 'Interest Area' CONTAINS '" + interest + "'"); 
}
function statusMap(status) {
 layer.setQuery("SELECT Address, 'Status' FROM " + tableid + " WHERE 'Status' CONTAINS '" + status + "'"); 
}
</script>

 </script> 

</head> 
<body onload="initialize();">  
  Internship Status <select onchange="interestMap(this.value);"> 
    <option value="">Interest Areas</option>
<option value="Aerospace">Aerospace</option>
<option value="Animals">Animals</option>
<option value="Architecture">Architecture</option>
<option value="Art/Music/Theatre">Art/Music/Theatre</option>
<option value="Athletics and Martial Arts">Athletics</option>
<option value="Automotive and Transportation">Automotive</option>
<option value="Business">Business</option>
<option value="Community Development">Community Development</option>
<option value="Computers">Computers</option>
<option value="Cosmetology">Cosmetology</option>
<option value="Culinary">Culinary</option>
<option value="Education">Education</option>
<option value="Government and Politics">Politics</option>
<option value="Health Science">Health Science</option>
<option value="Hospitality/Tourism/Event Planning">Event Planning</option>
<option value="Law and Public Safety">Law and Public Safety</option>
<option value="Marketing">Marketing</option>
<option value="Media and Information Technology">Media</option>
<option value="Photography">Photography</option>
<option value="Science and Technology">Science and Technology
</option>
<option value="Social Services">Social Services</option>
  </select>
   Status <select onchange="statusMap(this.value);"> 
    <option value="">Status</option>
<option value="BEING PURSUED">Being Pursued</option>
<option value="HAS INTERN">Has Intern</option>
<option value="NOT TAKING">Not Taking</option>
<option value="OPPORTUNITY">Opportunity</option>
<option value="OVER 18">Over 18</option>
<option value="POTENTIAL?">Potential</option>
<option value="SEE NOTES">See Notes</option>


  </select>
  <div id="map_canvas"></div>

</body> 
</html>

助けてくれてありがとう。

4

1 に答える 1

0

フィルタリング用に 2 つの異なる関数を用意する代わりに、両方のドロップダウン リストの値に基づいてフィルタリングする関数を作成します。

このようなもの:

function filterResults(){
    var interest = document.getElementById('ddl-interest').value;
    var status = document.getElementById('ddl-status').value;

    layer.setQuery("SELECT Address, 'Interest Area' FROM " + tableid + 
    " WHERE 'Interest Area' CONTAINS '" + interest + "' AND 'Status' CONTAINS '" + status + "'");
}

次に、ドロップダウン リストに 'ddl-interest' および 'ddl-status' という ID を指定し、onchange イベントで 'filterResults' メソッドを呼び出す必要があります。

于 2011-07-14T07:45:48.307 に答える