JavaScriptがクライアント側でPHPがサーバー側であり、それが問題を複雑にしていることは知っていますが、これをどうやって行うのかと思います。Javascript配列をPHPファイルに渡す
私はJavaScriptファイル(HTMLファイル)に配列を持っています。ユーザーが送信ボタンを押すと、その配列をPHPページに送信して、その日付をとり、 SQLデータベース。
これを行う簡単な方法はありますか?私の配列はvar markers = [];
のように宣言されています。これはコードのjavascript部分の単なる変数です。
私はこれに関する他の投稿を見てきましたが、すべての解決策は私が必要とするものに合っていないか、今私ができることのためにあまりにも多くの変更を必要としています。私はAJAXやJSONに精通していません。
マイJavascriptがある:
var markers = [];
function placeMarker(location) {
var clickedLocation = new google.maps.LatLng(location);
var name = document.getElementById("checkname").value;
var description = document.getElementById("description").value;
var marker = new google.maps.Marker({
position: location,
map: map,
title: name,
// This may cause a problem when reloading and editing an existing tour
// url was found at: http://biostall.com/adding-number-or-letters-to-google-maps-api-markers
icon: 'http://chart.apis.google.com/chart?chst=d_map_pin_letter&chld=' + markerId + '|FE6256|000000'
});
marker.setMap(map);
markers.push([markerId, name, marker.getPosition().lat(), marker.getPosition().lng(), description]);
//alert("" + markers);
markerId = markerId + 1;
}
google.maps.event.addListener(map, 'click', function(event) {
placeMarker(event.latLng);
});
google.maps.event.addListener(marker, "click", function() {
map.removeOverlay(marker);
marker.setMap(map);
});
}
window.onload = function() {
var form = document.getElementById('theform');
form.addEventListener('submit', function(){
var markersField = document.getElementById('markers');
markersField.value = JSON.stringify(markers);
});
}
私のHTMLは次のとおりです。私のportal.phpファイルで
<form action="portal.php" method="post" id="theform">
<input type="hidden" id="markers" name="markers">
<button>Submit</button>
</form>
私が持っている:
$markers = json_decode($_POST['markers']);
echo $markers;
何でもPHPページで出力していません配列に要素があることはわかっていますが、これは配列が渡されていないと信じさせてくれます。
あなたはAJAXについてよく知っておく必要があります。それはこれを行う唯一の方法です... –
これを行うための唯一の方法は、何らかの種類のAjaxソリューションです。経験があれば、jQueryはとても簡単です。 – dmikester1