2016-12-20 19 views
0

selectのリーフレットマップがあります。 selectには、座標を値として持つ場所が含まれています。リーフレット:選択が変更されたときの地図の中心の変更

selectを変更すると、マップは選択の値に応じてマップセンターをリロードして変更する必要があります。

は、ここに私のコードです:

var coor =[11.5303, 122.6842]; 
 
var mymap = L.map('mapid').setView(coor, 13); 
 

 
       L.tileLayer('https://api.tiles.mapbox.com/v4/{id}/{z}/{x}/{y}.png?access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpandmbXliNDBjZWd2M2x6bDk3c2ZtOTkifQ._QA7i5Mpkd_m30IGElHziw', { 
 
maxZoom: 18, 
 

 
id: 'mapbox.streets' 
 
}).addTo(mymap); 
 

 

 
mymap.on('click', onMapClick);
<link href="https://unpkg.com/[email protected]/dist/leaflet.css" rel="stylesheet"/> 
 
<script src="https://unpkg.com/[email protected]/dist/leaflet.js"></script> 
 

 

 
<div style="border:1px solid grey; width:500px;height:310px; margin:0 auto; margin-top:20px;"> 
 
<select id="loc" onchange="change_map()"> 
 
    <option value="[11.5529, 122.7407]">Roxas City</option> 
 
    <option value="[11.5303, 122.6842]">Ivisan</option> 
 
</select> 
 
<div id="mapid" style="width: 100%; height: 100%;"></div> 
 
</div>

答えて

1

私はあなたがオプション値にvalue = "[11.5529, 122.7407]"を使ってやりたいことができませんでした。

最初にselectタグのvalueを変更してください。例えば:あなたの機能onchange

<select id="loc" onchange="change_map()"> 
    <option value="1">Roxas City</option> 
    <option value="2" selected>Ivisan</option> 
</select> 

は、次の操作を行います。

// onchange function (this format makes the function global) 
window.change_map = function(){ 
    // Get the select element 
    var e = document.getElementById("loc"); 
    // Get the value of the selected index 
    var v = e.value; 

    // Verify the value and set the map to the new center 
    if(v == "1"){ mymap.setView([11.5529, 122.7407], zoom); } 
    else if(v == "2") { mymap.setView([11.5303, 122.6842], zoom); } 
} 

はここJSFiddle exampleです。

他の提案があります。

希望しました。

+0

それは私のコードとは異なる場合は、大丈夫です。 。答えに感謝します。それは動作します。=) –

+0

ようこそ。私はそれがうまくいってうれしいです。 –

関連する問題